例:シンプルなDXPクラスターの作成
DXP クラスタリングを習得する迅速かつ簡単な方法は、 Docker コンテナを使用して 1 台のマシンに 2 ノードの DXP クラスタ環境をセットアップすることです。 この例では、データベース、検索エンジン、およびファイル ストアのサーバー コンテナーとともに、2 つの DXP サーバー コンテナーを作成します。
| サーバータイプ | 実施 | コンテナ名 |
|---|---|---|
| データベース | MariaDB | some-mariadb |
| ファイルストア | DBStore | some-mariadb |
| 検索エンジン | Elasticsearch | elasticsearch |
| DXPサーバー | Tomcat | dxp-1 |
| DXPサーバー | Tomcat | dxp-2 |
この例は学習を目的としたものであり、本番環境のユースケースには適していません。 本番環境では、DXPサーバーへのリクエストの負荷分散用にHTTPサーバーを含め、読み取り専用操作と読み取り/書き込み操作に別々のデータベースサーバーを使用し、データベースサーバー、ファイルストアサーバー、および検索エンジンサーバーのクラスタリングと負荷分散を検討する必要があります。 詳細については、 高可用性のためのクラスタリング を参照してください。
主な手順は次のとおりです。
データベースサーバーを起動する
DXPクラスターには、すべてのDXPクラスターノードからアクセスできるデータソースが必要です。 データソースは、JNDIデータソースにするか、データベースサーバーまたはデータベースサーバークラスターへの直接接続にすることができます。 DXP バージョンがサポートするデータベース サーバーについては、 互換性マトリックス を参照してください。
データベースサーバーとDXPデータベースを作成します。
-
MariaDB Dockerコンテナを起動します。
docker run --name some-mariadb -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mariadb:10.2 -
コンテナ上のシェルで、 DXP データベースを作成します。
データベースサーバーにサインインします。
docker exec -it some-mariadb bash -c "/usr/bin/mysql -uroot -pmy-secret-pw"DXP用のデータベースを作成します。
create database dxp_db default character set utf8mb4 collate utf8mb4_unicode_ci;データベースセッションを終了します。
quitbashセッションを終了します。
exit
データベースサーバーでDXP用の準備が整いました。 詳細については、 クラスターノードのデータベース構成 を参照してください。
ファイルストアサーバーを起動する
DXPクラスターには、すべてのDXPクラスターノードからアクセスできるファイルストアが必要です。 便宜上、この例では DXP データベースに構成された DBStore ファイル ストア を使用します。 この例ですでに起動しているデータベースサーバーには、ファイルストアが含まれています。 すべてのファイル ストア タイプの構成については、 ファイル ストレージの構成 を参照してください。
検索エンジンサーバーを起動する
DXPクラスターには、すべてのDXPクラスターノードからアクセス可能な検索エンジン(個別のプロセスとして実行)が必要です。 詳細については、「 検索エンジンのインストール 」を参照してください。
Elasticsearchサーバーを作成して設定します。
-
Elasticsearchサーバーのデータボリュームを保存するためのローカルフォルダを設定します。 例えば、
mkdir -p elasticsearch/es_data_volume -
elasticsearchという名前のElasticsearchコンテナを起動します。docker run -it --name elasticsearch -p 9200:9200 -p 9300:9300 -e cluster.name=LiferayElasticsearchCluster -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -v $(pwd)/elasticsearch/es_data_volume:/var/lib/elasticsearch/data elasticsearch:6.8.7注コンテナーが
最大仮想メモリ領域 vm.max_map_count [xxxxx] が低すぎると報告する場合は、少なくとも [xxxxxx]まで増やしてから、次のようなコマンドを使用してvm.max_map_countを十分な値に設定します:sudo sysctl -w vm.max_map_count=[xxxxxx]。 次に、コンテナを起動します。 -
必要なElasticsearchプラグインをインストールします。
docker exec -it elasticsearch bash -c '/usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-icu && /usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-kuromoji && /usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-smartcn && /usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-stempel'
検索エンジンは検索インデックスを管理する準備ができました。
ノードごとに検索エンジンサーバーを設定する
設定ファイル を使用して、各 DXP ノードの Elasticsearch を設定します。
-
設定ファイルの場所を作成します。
mkdir -p dxp-1/files/osgi/configs dxp-2/files/osgi/configs -
dxp-1サーバーノードのElasticsearchを設定します。cat <<EOT >> dxp-1/files/osgi/configs/com.liferay.portal.search.elasticsearch6.configuration.ElasticsearchConfiguration.config operationMode="REMOTE" transportAddresses="elasticsearch:9300" clusterName="LiferayElasticsearchCluster" EOT -
dxp-2サーバーノードのElasticsearchを設定します。cat <<EOT >> dxp-2/files/osgi/configs/com.liferay.portal.search.elasticsearch6.configuration.ElasticsearchConfiguration.config operationMode="REMOTE" transportAddresses="elasticsearch:9300" clusterName="LiferayElasticsearchCluster" EOT
これらの設定ファイルを、DXPサーバーコンテナのバインドマウントを介してクラスターノードからアクセスできるようにします。
docker run --add-host elasticsearch:[ip] ... 後ほど DXP サーバー用に使用されるコマンドは、名前 elasticsearch を Elasticsearch サーバー ホストの IP アドレスにマッピングする /etc/hosts/ エントリを追加します。
DXPクラスターを開始する
-
docker network inspect bridgeコマンドを実行して、elasticsearchおよびsome-mariadbコンテナのコンテナ IP アドレスを取得します。bridgeネットワークがデフォルトネットワークです。重要後続の
docker runコマンドで、[IP アドレス]をelasticsearchおよびsome-mariadbコンテナの IP アドレスに置き換えます。 -
dxp-1を開始します。読みやすいように拡張されたコマンド:
docker run -it \ --add-host elasticsearch:[IP address] \ --add-host some-mariadb:[IP address] \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_JNDI_PERIOD_NAME="" \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_DRIVER_UPPERCASEC_LASS_UPPERCASEN_AME=org.mariadb.jdbc.Driver \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_URL="jdbc:mariadb://some-mariadb:3306/dxp_db?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false" \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_USERNAME=root \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_PASSWORD=my-secret-pw \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_ENABLED=true \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_CONTROL=control-channel-logic-name-1 \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_TRANSPORT_PERIOD_NUMBER0=transport-channel-logic-name-1 \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_AUTODETECT_PERIOD_ADDRESS=some-mariadb:3306 \ -e LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=true \ -e LIFERAY_DL_PERIOD_STORE_PERIOD_IMPL=com.liferay.portal.store.db.DBStore \ --name dxp-1 \ -p 11311:11311 \ -p 8009:8009 \ -p 8080:8080 \ -v $(pwd)/dxp-1:/mnt/liferay \ liferay/portal:7.4.3.132-ga1321行に凝縮されたコマンド:
docker run -it --name dxp-1 --add-host elasticsearch:[IP address] --add-host some-mariadb:[IP address] -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_JNDI_PERIOD_NAME="" -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_DRIVER_UPPERCASEC_LASS_UPPERCASEN_AME=org.mariadb.jdbc.Driver -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_URL="jdbc:mariadb://some-mariadb:3306/dxp_db?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false" -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_USERNAME=root -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_PASSWORD=my-secret-pw -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_ENABLED=true -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_CONTROL=control-channel-logic-name-1 -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_TRANSPORT_PERIOD_NUMBER0=transport-channel-logic-name-1 -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_AUTODETECT_PERIOD_ADDRESS=some-mariadb:3306 -e LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=true -e LIFERAY_DL_PERIOD_STORE_PERIOD_IMPL=com.liferay.portal.store.db.DBStore --name dxp-1 -p 11311:11311 -p 8009:8009 -p 8080:8080 -v $(pwd)/dxp-1:/mnt/liferay liferay/portal:7.4.3.132-ga132 -
dxp-2を起動します。読みやすいように拡張されたコマンド:
docker run -it \ --add-host elasticsearch:[IP address] \ --add-host some-mariadb:[IP address] \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_JNDI_PERIOD_NAME="" \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_DRIVER_UPPERCASEC_LASS_UPPERCASEN_AME=org.mariadb.jdbc.Driver \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_URL="jdbc:mariadb://some-mariadb:3306/dxp_db?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false" \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_USERNAME=root \ -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_PASSWORD=my-secret-pw \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_ENABLED=true \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_CONTROL=control-channel-logic-name-2 \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_TRANSPORT_PERIOD_NUMBER0=transport-channel-logic-name-2 \ -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_AUTODETECT_PERIOD_ADDRESS=some-mariadb:3306 \ -e LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=true \ -e LIFERAY_DL_PERIOD_STORE_PERIOD_IMPL=com.liferay.portal.store.db.DBStore \ --name dxp-2 \ -p 11312:11311 \ -p 9009:8009 \ -p 9080:8080 \ -v $(pwd)/dxp-2:/mnt/liferay \ liferay/portal:7.4.3.132-ga1321行に凝縮されたコマンド:
docker run -it --add-host elasticsearch:[IP address] --add-host some-mariadb:[IP address] -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_JNDI_PERIOD_NAME="" -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_DRIVER_UPPERCASEC_LASS_UPPERCASEN_AME=org.mariadb.jdbc.Driver -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_URL="jdbc:mariadb://some-mariadb:3306/dxp_db?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false" -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_USERNAME=root -e LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_PASSWORD=my-secret-pw -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_ENABLED=true -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_CONTROL=control-channel-logic-name-2 -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME_PERIOD_TRANSPORT_PERIOD_NUMBER0=transport-channel-logic-name-2 -e LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_AUTODETECT_PERIOD_ADDRESS=some-mariadb:3306 -e LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=true -e LIFERAY_DL_PERIOD_STORE_PERIOD_IMPL=com.liferay.portal.store.db.DBStore --name dxp-2 -p 11312:11311 -p 9009:8009 -p 9080:8080 -v $(pwd)/dxp-2:/mnt/liferay liferay/portal:7.4.3.132-ga132
--add-host [ドメイン]:[IP アドレス] オプション は、ドメイン名を IP アドレスにマッピングする /etc/hosts ファイル エントリ を追加します。 これにより、構成 (環境変数、ポータル プロパティ、 .config ファイルなど) がドメイン名でサーバーを参照できるようになります。
-e [variable]=[value]オプションは、DXPコンテナ環境変数を設定します。 詳細については、 付録A: 環境設定 を参照してください。
DXP クラスター ノード コンテナーには、次の固有の設定があります。
| 設定 | dxp-1 | dxp-2 |
|---|---|---|
| AJPポートマッピング | 8009:8009 | 9009:8009 |
| HTTPポートマッピング | 8080:8080 | 9080:8080 |
| OSGiコンテナポートマッピング | 11311:11311 | 11312:11311 |
| バインドマウント | $(pwd)/dxp-1:/mnt/liferay | $(pwd)/dxp-2:/mnt/liferay |
| クラスターリンク制御チャネルのロジック名 | control-channel-logic-name-1 | control-channel-logic-name-2 |
| クラスターリンクトランスポートチャネルのロジック名 | transport-channel-logic-name-1 | transport-channel-logic-name-2 |
DXPノードにアクセスする
DXPクラスターノードは、次のURLで入手できます。
- DXP-1:http://localhost:8080
- DXP-2:http://localhost:9080
次の図は、クラスターノードのホームページを示しています。

各ノードのコンテナIDとポート(ノード: [id]:[port])は、各ページの下部に表示されます。 LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=true環境設定により、この表示機能が有効になりました。 docker container ls コマンドを使用して、コンテナの ID を見つけることができます。
コンテンツを検索エンジンにインデックス付けする
-
コントロール パネル → 構成 → 検索に移動します。
-
[インデックス アクション] タブで、 [すべての検索インデックスの再インデックス化] と [すべてのスペル チェック インデックスの再インデックス化]をクリックします。
コンテンツは検索エンジンにインデックス付けされます。 詳細については、 検索の概要 を参照してください。
DXPクラスターをテストする
ノード間のデータ同期をテストします。
-
クラスタノードの1つにコンテンツを追加します。 たとえば、New Stuffという名前の新しいウィジェットページを追加し、それに言語セレクタウィジェットを追加します。
-
他のクラスターノードのUIを更新します。
両方のノードに同じ新しいコンテンツが表示されます。

これで作業中の DXPクラスタを作成できました!
次のステップ
DXP クラスター用にデータベース を構成します。
付録A:環境設定
サンプルの DXP サーバー コンテナーでは、これらの設定が使用されます。
| 設定 | 説明 |
|---|---|
| LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_JNDI_PERIOD_NAME= | データソースJNDI名 |
| LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_DRIVER_UPPERCASEC_LASS\ _UPPERCASEN_AME=\ org.mariadb.jdbc.Driver | データベースドライバークラス |
| LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_URL=\ jdbc:mariadb://some-mariadb:3306/dxp_db?\ useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false | データソースURL |
| LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_USERNAME=\ ルート | データベース管理者のユーザー名 |
| LIFERAY_JDBC_PERIOD_DEFAULT_PERIOD_PASSWORD=\ 私の秘密のパスワード | データベース管理者ユーザーのパスワード |
| LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_ENABLED=\ 真 | クラスタリンクを有効にする |
| LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME\ _PERIOD_CONTROL=\ 制御チャネルロジック名2 | クラスターノードの一意のコントロールチャネル名 |
| LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_CHANNEL_PERIOD_LOGIC_PERIOD_NAME\ _PERIOD_TRANSPORT_PERIOD_NUMBER0=\ トランスポートチャネルロジック名2 | クラスターノードの一意のトランスポートチャネル名 |
| LIFERAY_CLUSTER_PERIOD_LINK_PERIOD_AUTODETECT_PERIOD_ADDRESS=\ some-mariadb:3306 | クラスターノードアドレスを取得するためにpingする既知のアドレス |
| LIFERAY_WEB_PERIOD_SERVER_PERIOD_DISPLAY_PERIOD_NODE=\ 真 | サーバーアドレスとウェブサーバーポートを表示します |
| LIFERAY_DL_PERIOD_STORE_PERIOD_IMPL=\ com.liferay.portal.store.db.DBStore | ファイルストア(ドキュメントライブラリストア)クラス |
詳細については、Env/ポータル プロパティ の定義を参照してください。