OpenSearch サービスの設定
作成対象:
- 管理者
- 開発者
OpenSearch サービスは、Elasticsearchのライセンスの変更に伴い、Elasticsearch7.10.2 のオープンソースのフォークになりました。 詳しくは、GitHub の OpenSource プロジェクトを参照してください。
OpenSearch を使用すると、任意のソース、任意の形式からデータを取得し、リアルタイムで検索および視覚化できます。
- 製品カタログ内の製品に対するクイック検索と詳細検索
- OpenSearch アナライザーは複数の言語をサポートしています
- ストップワードおよび同義語のサポート
- インデックス再作成が完了するまで、インデックス作成は顧客に影響しません
master
ブランチを含む Pro 統合環境とスターター環境でのサービス設定については、以下の手順を使用します。
OpenSearch を有効にするには:
-
スターターおよび Pro 統合環境の場合は、適切なバージョンと割り当てられたディスク容量(MB 単位)を使用して
opensearch
サービスを.magento/services.yaml
ファイルに追加します。 この場合、バージョン 2 が適切です。 クラウドインフラストラクチャでは最新バージョンの OpenSearch が使用されるので、マイナーバージョンは必要ありません。opensearch: type: opensearch:2 disk: 1024
Pro プロジェクトの場合、ステージング環境と実稼動環境で OpenSearch バージョンを変更するには、Adobe Commerce サポートチケットを送信する必要があります。
-
.magento.app.yaml
ファイルのrelationships
プロパティを設定または確認します。relationships: opensearch: "opensearch:opensearch"
-
コードの変更を追加、コミットおよびプッシュします。
git add .magento/services.yaml .magento.app.yaml
git commit -m "Enable OpenSearch"
git push origin <branch-name>
これらの変更が環境に与える影響について詳しくは、 サービスの設定を参照してください。
-
デプロイメントプロセスが完了したら、SSH を使用してリモート環境にログインします。
magento-cloud ssh
-
カタログ検索インデックスを再インデックス化します。
bin/magento indexer:reindex catalogsearch_fulltext
-
キャッシュをクリーンアップします。
bin/magento cache:clean
services.yaml
および .magento.app.yaml
の構成ファイルを更新することで、インストールされているサービスのソフトウェア バージョンを変更できます。 サービスのアップグレードまたはダウングレードのガイダンスについては、 サービスバージョンの変更を参照してください。OpenSearch ソフトウェアの互換性
クラウドインフラストラクチャプロジェクトでAdobe Commerceをインストールまたはアップグレードする際は、常に OpenSearch サービスのバージョンと、Adobe Commerce用の OpenSearch PHP クライアントとの互換性を確認してください。
-
初回セットアップ-
services.yaml
ファイルで指定された OpenSearch バージョンが、Adobe Commerce用に設定された OpenSearch PHP クライアントと互換性があることを確認します。 -
プロジェクトのアップグレード – 新しいアプリケーションバージョンの OpenSearch PHP クライアントが、クラウドインフラストラクチャにインストールされた OpenSearch サービスバージョンと互換性があることを確認します。
サービスのバージョンと互換性のサポートは、Cloud Infrastructure でテストおよびデプロイされたバージョンによって決まり、Adobe Commerceのオンプレミスデプロイメントでサポートされているバージョンとは異なる場合があります。 サポートされているバージョンの一覧については、『インストール ガイド の 🔗 システム要件 を参照してください。
OpenSearch ソフトウェアの互換性を確認するには:
-
ローカルワークステーションで、をプロジェクトディレクトリに変更します。
-
アクティブな環境の OpenSearch の詳細を表示します。
magento-cloud relationships --property=opensearch
-
または、SSH を使用してリモート環境にログインすることもできます。
magento-cloud ssh
-
OpenSearch サービス接続の詳細を取得します。
vendor/bin/ece-tools env:config:show services
応答で、OpenSearch サービスエンドポイントの IP アドレスとポートを見つけます。
+------------------------------------------+--------------------------------------------------------+ | opensearch: | +------------------------------------------+--------------------------------------------------------+ | username | null | | scheme | http | | service | opensearch | | fragment | null | | ip | 169.254.220.11 | | hostname | hostf75wi3sd24l.opensearch.service._.magentosite.cloud | | port | 9200 | | cluster | projectID-develop-4ranwui | | host | opensearch.internal | | rel | opensearch | | path | null | | query | | | password | null | | type | opensearch:2 | | public | false | | host_mapped | false |
-
サービスエンドポイントから、インストールされている OpenSearch サービス
version:number
を取得します。curl -XGET <opensearch-service-endpoint-ip-address>:9200
{ "name" : "opensearch.0", "cluster_name" : "opensearch", "cluster_uuid" : "_yzaae6-ywSEW1MaAF8ZPWyQ", "version" : { "distribution" : "opensearch", "number" : "2.5.0", "build_type" : "deb", "build_hash" : "aaaaaaa", "build_date" : "2023-01-23T12:07:18.760675Z", "build_snapshot" : false, "lucene_version" : "9.4.2", "minimum_wire_compatibility_version" : "7.10.0", "minimum_index_compatibility_version" : "7.0.0" }, "tagline" : "The OpenSearch Project: https://opensearch.org/" }
Staging
および Production
環境でのみ サービスをインストールまたは更新するには、Adobe Commerce サポートチケットを送信する必要があります。.magento.app.yaml
ファイルと services.yaml
ファイルを含め、PHP バージョンをチケットに記載します。 PHP のバージョン、拡張機能、または環境設定のセルフサービスでの変更については、 アプリケーション設定 _のPHP 設定_ を参照してください。OpenSearch サービスを再起動します
OpenSearch サービスを再起動する必要がある場合は、Adobe Commerce サポートに連絡してください。
追加の検索設定
-
デフォルトでは、クラウド環境の検索設定は、デプロイするたびに再生成されます。
SEARCH_CONFIGURATION
デプロイ変数を使用して、デプロイメント間でカスタム検索設定を保持できます。 変数のデプロイを参照してください。 -
プロジェクトの OpenSearch サービスを設定した後、管理 UI を使用して OpenSearch 接続をテストし、Adobe Commerceの OpenSearch 設定をカスタマイズします。
OpenSearch 用プラグインの追加
オプションで、.magento/services.yaml
ファイルの OpenSearch サービスに configuration:plugins
セクションを追加することで、OpenSearch 用のプラグインを追加できます。 例えば、次のコードは ICU 分析と音声分析プラグインを有効にします。
opensearch:
type: opensearch:2
disk: 1024
configuration:
plugins:
- analysis-icu
- analysis-phonetic
プラグインについて詳しくは、OpenSearch プロジェクトを参照してください。
OpenSearch のプラグインを削除
.magento/services.yaml
ファイルの opensearch:
セクションからプラグイン エントリを削除しても、サービスはアンインストールまたは無効化 されません。 このサービスを完全に無効にするには、.magento/services.yaml
ファイルからプラグインを削除した後、OpenSearch データのインデックスを再作成する必要があります。 この設計により、これらのプラグインに依存するデータの損失や破損を防ぐことができます。
OpenSearch プラグインを削除するには:
-
.magento/services.yaml
ファイルから OpenSearch プラグインのエントリを削除します。 -
コードの変更を追加、コミット、プッシュします。
git add .magento/services.yaml
git commit -m "Remove OpenSearch plugin"
git push origin <branch-name>
-
.magento/services.yaml
の変更をクラウドリポジトリにコミットします。 -
カタログ検索インデックスを再インデックス化します。
bin/magento indexer:reindex catalogsearch_fulltext
-
キャッシュをクリーンアップします。
bin/magento cache:clean