DSRP的MySQL配置

MySQL是關係資料庫,可用於儲存用戶生成的內容(UGC)。

這些說明說明如何連接到MySQL Server並建立UGC資料庫。

需求

安裝MySQL

🔗 MySQL應按照目標OS的說明下載和安裝。

小寫表名

由於SQL不區分大小寫,因此對於區分大小寫的作業系統,必須包含一個設定來將所有表名都小寫。

例如,要指定Linux OS上所有小寫表名:

  • 編輯檔案/etc/my.cnf

  • [mysqld]區段中,新增下列行:

    lower_case_table_names = 1

UTF8字元集

若要提供更好的多語言支援,必須使用UTF8字元集。

將MySQL更改為以UTF8作為其字元集:

  • mysql >設定名稱'utf8';

將MySQL資料庫更改為預設UTF8:

  • 編輯檔案/etc/my.cnf

  • [client]區段中,新增下列行:

    default-character-set=utf8

  • [mysqld]區段中,新增下列行:

    character-set-server=utf8

安裝MySQL Workbench

MySQL Workbench提供了用於執行SQL指令碼的UI,這些指令碼安裝架構和初始資料。

MySQL Workbench應按照目標作業系統的說明下載並安裝。

Communities Connection

MySQL Workbench首次啟動時(除非已用於其他用途),它將不會顯示任何連線:

mysqlconnection

新連接設定

  1. 選擇MySQL Connections右側的+表徵圖。

  2. 在對話方塊Setup New Connection中,輸入適合您平台的值

    為了示範,將製作AEM例項和MySQL放在相同的伺服器上:

    • 連接名:Communities
    • 連接方法:Standard (TCP/IP)
    • 主機名:127.0.0.1
    • 使用者名稱: root
    • 密碼: no password by default
    • 預設架構:leave blank
  3. 選擇Test Connection以驗證與正在運行的MySQL服務的連接

附註:

  • 預設埠為3306
  • JDBC OSGi配置中,選擇的連接名作為資料源名輸入

新建Communities連接

社群連線

資料庫設定

開啟Communities連接以安裝資料庫。

install-database

獲取SQL指令碼

從AEM儲存庫獲取SQL指令碼:

  1. 瀏覽至CRXDE Lite

  2. 選取/libs/social/config/datastore/dsrp/schema資料夾

  3. 下載 init-schema.sql

    database-schema-crxde

下載架構的方法之一是:

  • 為sql檔案選擇jcr:content節點

  • 請注意,jcr:data屬性的值是檢視連結

  • 選取檢視連結,將資料儲存至本機檔案

建立DSRP資料庫

請依照下列步驟安裝資料庫。 資料庫的預設名稱為communities

如果在指令碼中更改了資料庫名稱,請確保在JDBC配置中也更改了該名稱。

步驟1:開啟SQL檔案

在MySQL Workbench中

  • 從「檔案」下拉菜單中,選擇​開啟SQL指令碼​選項
  • 選擇下載的init_schema.sql指令碼

select-sql-script

步驟2:執行SQL指令碼

在Workbench視窗中,針對在步驟1中開啟的檔案選取lightening (flash) icon以執行指令碼。

在下圖中,init_schema.sql檔案已準備好執行:

execute-sql-script

重新整理

執行指令碼後,必須刷新NavigatorSCHEMAS部分,才能查看新資料庫。 使用「結構」右側的刷新表徵圖:

刷新架構

配置JDBC連接

Day Commons JDBC連接池​的OSGi配置配置MySQL JDBC驅動程式。

所有發佈和製作AEM例項都應指向相同的MySQL伺服器。

當MySQL在與AEM不同的伺服器上運行時,必須指定伺服器主機名來取代JDBC連接器中的「localhost」。

  • 在每個製作和發佈AEM例項上。

  • 以管理員權限登錄。

  • 訪問Web控制台

  • 找到Day Commons JDBC Connections Pool

  • 選擇+表徵圖以建立新的連接配置。

    configure-jdbc-connection

  • 輸入下列值:

    • JDBC驅動程式類: com.mysql.jdbc.Driver

    • JDBC連接URI: jdbc:mysql://localhost:3306/communities?characterEncoding=UTF-8

      如果MySQL伺服器與'this' AEM server communities​是預設資料庫(架構)名稱,請指定伺服器以取代localhost。

    • 使用者名稱: root

      或者,輸入MySQL伺服器的配置用戶名(如果不是「root」)。

    • 密碼:

      如果未為MySQL設定密碼,請清除此欄位,

      否則,請輸入MySQL用戶名的配置密碼。

    • 資料源名稱:為MySQL連 接輸入的名稱,例如「communities」。

  • 選擇​保存

本頁內容