検索エンジン設定
この節では、Adobe CommerceのオンプレミスのデプロイメントでElasticsearchまたはOpenSearchをテストするために選択する必要がある最小設定について説明します。
Elasticsearch 8.xのサポートがバージョン 2.4.6で導入されたときには、ElasticsearchとOpenSearchの設定を区別するために新しいラベルが作成されました。
検索エンジンの設定について詳しくは、 ユーザーガイド を参照してください。
管理者から検索エンジンを設定します
ElasticsearchまたはOpenSearchを使用するようにシステムを設定するには:
-
管理者としてAdminにログインします。
-
Stores > Settings > Configuration > Catalog > Catalog > Catalog Searchをクリックします。
-
Search Engine リストから、対応する検索エンジンのバージョンを選択します。
次の表に、Commerceとの接続を設定およびテストするために必要なオプションを示します。 検索エンジンのサーバー設定を変更しない限り、デフォルトは機能する必要があります。 次の手順に進みます。
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 オプション 説明 Server Hostname ElasticsearchまたはOpenSearchを実行しているマシンの完全修飾ホスト名またはIP アドレスを入力します。
Adobe Commerce クラウド インフラストラクチャ版:統合システムからこの値を取得します。Server Port Web サーバープロキシポートを入力します。 デフォルトは、クラウドインフラストラクチャ上の9200
Adobe Commerceです。この値を取得するには、統合システムを使用します。Index Prefix 検索エンジンのインデックス接頭辞を入力します。 1つのインスタンスを複数のCommerce インストール(ステージング環境および実稼動環境)で使用する場合は、各インストールに一意のプレフィックスを指定する必要があります。 それ以外の場合は、デフォルトの接頭辞magento2を使用できます。 Enable HTTP Auth 検索エンジンサーバーの認証を有効にしている場合にのみ、Yesをクリックします。 その場合は、指定したフィールドにユーザー名とパスワードを入力します。 Server Timeout ElasticsearchまたはOpenSearch サーバーへの接続を確立する際に待機する時間(秒単位)を入力します。 -
Test Connectionをクリックします。
回答サンプル:
次でログイン:
ご覧の通り:
その場合は、次のことをお試しください。
-
検索エンジンサーバーが実行されていることを確認します。
-
サーバーがCommerceとは異なるホスト上にある場合は、Commerce サーバーにログインし、検索エンジンホストにpingを送信します。 ネットワーク接続の問題を解決し、接続を再度テストします。
-
ElasticsearchまたはOpenSearchを開始したコマンドウィンドウで、スタックトレースと例外を確認します。 続行する前にそれらを解決する必要があります。 特に、
root権限を持つユーザーとして検索エンジンを開始していることを確認してください。 -
UNIX ファイアウォールとSELinuxの両方が無効になっていることを確認するか、検索エンジンとCommerceが互いに通信できるようにルールを設定します。
-
Server Hostname フィールドの値を確認します。 サーバーが使用可能であることを確認します。 代わりに、サーバーのIP アドレスを試すことができます。
-
netstat -an | grep <listen-port>コマンドを使用して、Server Port フィールドで指定されたポートが別のプロセスで使用されていないことを確認します。例えば、検索エンジンがデフォルトポートで実行されているかどうかを確認するには、次のコマンドを使用します。
code language-shell netstat -an | grep 9200ポート 9200で実行している場合は、次のように表示されます。
code language-text `tcp 0 0 :::9200 :::- LISTEN`
カタログ検索のインデックスを再作成し、ページ全体のキャッシュを更新する
検索エンジンの設定を変更したら、カタログ検索インデックスを再インデックスし、管理者またはコマンドラインを使用して完全なページキャッシュを更新する必要があります。
管理者を使用してキャッシュを更新するには:
-
管理者で、System > Cache Managementをクリックします。
-
Page Cacheの横にあるチェックボックスを選択します。
-
右上のActions リストから、更新をクリックします。
コマンドラインを使用してキャッシュをクリーンアップするには:bin/magento cache:clean
コマンドラインを使用してインデックスを再作成するには:
-
ファイルシステム所有者としてCommerce サーバーにログインするか、切り替えます。
-
次のいずれかのコマンドを入力します。
カタログ検索インデックスのみを再インデックス化するには、次のコマンドを入力します。
code language-shell bin/magento indexer:reindex catalogsearch_fulltextすべてのインデクサーを再インデックス化するには、次のコマンドを入力します。
code language-shell bin/magento indexer:reindex -
インデックス再作成が完了するまで待ちます。
note info INFO キャッシュとは異なり、インデックスはcron ジョブによって更新されます。 検索エンジンの使用を開始する前に、cronが有効になっていることを確認してください。