この記事では主にDockerを使ってElasticSearch:バージョン6.8.4をデプロイする方法について説明しています。Dockerからpullして最終的にElasticSearchを実行し、ElasticSearch関連の情報を管理するための小さなツールであるElasticSearch-Headをインストールする方法について説明します。このブログシステムのホームページの検索はElasticSearchを使用して実装されています。ElasticSearchは更新が速く、SpringData-ElasticSearchがEsの更新に追いつけないため、最初はバージョン8.xもダウンロードしましたが、SpringData-ElasticSearchがエラーを報告しました。最終的に6.8.4を選択しました。ここに記録します 1. ElasticSearch の Docker デプロイメント: バージョン 6.8.4 1.1 イメージを取得する docker pull docker.elastic.co/elasticsearch/elasticsearch:6.8.4 1.2 コンテナを実行する ElasticSearch のデフォルト ポートは 9200 です。ホスト環境のポート 9200 を Docker コンテナのポート 9200 にマッピングすると、Docker コンテナ内の ElasticSearch サービスにアクセスできます。同時に、このコンテナに es という名前を付けます。 docker run -d --name es -p 9200:9200 -p 9300:9300 -e "検出タイプ=単一ノード" -e ES_JAVA_OPTS="-Xms=256m -Xms=256m" 6.8.4 より前のバージョン 例: -e discovery.type=single-node: 単一ノードの起動を示します -e ES_JAVA_OPTS="-Xms=256m -Xms=256m" : ES 起動時のメモリ サイズの設定を示します。これは必ず設定する必要があります。そうしないと、自分のひどいサーバーのように、後でメモリが不足することになります。 1.3 メモリ不足 Centos が elasticsearch をダウンロードして設定を変更した後、docker コマンドを実行します。 起動が成功しなかったことが判明しました。コマンドの-dを削除すると、次のエラーが表示されました。 Java HotSpot(TM) 64 ビット サーバー VM の警告: INFO: os::commit_memory(0x0000000085330000, 2060255232, 0) が失敗しました。 エラー='メモリを割り当てられません' (errno=12) 調べてみると、elasticsearch6.0 によって割り当てられたデフォルトの JVM スペース サイズが 2g であり、割り当てるメモリが不足していたことが原因であることがわかりました。 解決策は、jvm スペース割り当て実行コマンドを変更することです。 /var/lib/docker/overlay/ -name jvm.options を検索します。 jvm.options ファイルを見つけて、vi コマンドを使用して次のように jvm.options ファイルを開きます。 -Xms2g -Xmx2g -Xms512mに変更 -Xmx512m 保存して終了するだけです。再度、create および run elasticsearch コマンドを実行すると、正常に起動します。 2. Docker デプロイメント ElasticSearch-Heard 2.1 イメージを取得する docker pull mobz/elasticsearch-head:5 2.2 コンテナを実行する docker create --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5 2.3 コンテナを起動する docker で elasticsearch-head を起動します 2.4 ブラウザを開く: http://IP:9100 クロスドメインの問題で接続できないことがわかりました。フロントエンドとバックエンドは別々に開発されていたため、esを設定する必要がありました。 2.5 起動したばかりのesコンテナに入ります。コンテナ名 = es docker exec -it es /bin/bash 2.6 elasticsearch.ymlファイルを変更する vi config/elasticsearch.yml に追加 http.cors.enabled: 有効 http.cors.allow-origin: "*" 実際、SpringBootのymlファイルはクロスドメインサポートを追加します 2.7 コンテナを終了して再起動する 出口 docker 再起動 es 2.8 http://localhost:9100 にアクセスします。 要約: この記事では、Docker を使用して ElasticSearch をインストールする方法と、メモリ不足やバージョンが高すぎるなどの問題、ElasticSearch-Heard のインストールとクロスドメイン構成について簡単に説明します。次の記事では、ElasticSearch に中国語の単語セグメンターをインストールする方法について説明します。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MYSQLのバックアップデータのスケジュールクリアの特定の操作
>>: Vue 2つのフィールドの共同検証によりパスワード変更機能を実現
MySQL のデータ ディクショナリは、データベースの重要なコンポーネントの 1 つです。INFOR...
1. 現在のすべての接続の詳細情報を表示します。 ./mysqladmin -uadmin -p -...
効果: コード: <テンプレート> <div class="back-t...
現在、プロジェクトの要件により、フォームの送信を制御し、送信前にデータを検証および処理するために j...
新しい CSS 機能を使用する場合、その互換性は常に考慮されます。おそらく、その互換性、どのブラウザ...
この記事の例では、矢印をクリックして画像を切り替えるVue + jsの具体的なコードを共有しています...
以前、「MySQL でコミットされていないトランザクション情報を検索する方法」というタイトルのブログ...
私のは: <!DOCTYPE html>ブログガーデン: <!DOCTYPE HT...
目次1. ドラッグ効果の例2. CSS実装の原則3. CSS実装の詳細4. CSSレイアウト1. 固...
この記事では、Mysql WorkBenchのインストールと設定のグラフィックチュートリアルを参考ま...
目次序文1.nullでない2. ユニーク3. デフォルト4.主キー自動増分主キー5. 外部キー6.チ...
これは多くの人がやったことがあるはずです。ただうずうずして書きたかったので、時間をかけていじってダー...
この記事では、例を使用して MySQL の重複インデックスと冗長インデックスについて説明します。ご参...
1. MYSQLインストールディレクトリ次のようにコードをコピーします。 select @@bas...
最近、ウェブサイトを開発する際にトップに戻るボタンを作成する必要がありますが、私は主にバックエンドの...