Docker が elasticsearch を起動するときのメモリ不足の問題と解決策

Docker が elasticsearch を起動するときのメモリ不足の問題と解決策

質問

Docker が elasticsearch をインストールして起動するときにメモリが不足する

システム centos8 (Alibaba Cloud ecs サーバー)

[root@iZ2zeczvvb79boy368xppwZ ~]# cat /etc/redhat-release
CentOS Linux リリース 8.1.1911 (コア)

インストールプロセス

docker pull elasticsearch:6.4.0

仮想マシンのメモリを変更する(効果はないようです)

sysctl -w vm.max_map_count=262144

docker runコマンドを使用してコンテナを実行します。

docker run -p 9200:9200 -p 9300:9300 --name elasticsearch \
-e "discovery.type=シングルノード" \
-e "cluster.name=elasticsearch" \
-v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
-v /mydata/elasticsearch/data:/usr/share/elasticsearch/data \
-d エラスティックサーチ:6.4.0

Docker psはコンテナが起動していないことを示している

[root@iZ2zeczvvb79boy368xppwZ ~]# docker ps
コンテナID イメージ コマンド 作成ステータス ポート名
edfc400862eb rabbitmq:3.7.15 "docker-entrypoint.s..." 14 時間前 14 時間前にアップ 0.0.0.0:4369->4369/tcp、0.0.0.0:5671-5672->5671-5672/tcp、0.0.0.0:15671-15672->15671-15672/tcp、0.0.0.0:25672->25672/tcp rabbitmq
2ae2f3f8dc1f nginx:1.10 "nginx -g 'daemon of..." 2 週間前 2 週間前 0.0.0.0:80->80/tcp, 443/tcp nginx
164e4e7561df redis:3.2 "docker-entrypoint.s..." 2 週間前 2 週間前 0.0.0.0:6379->6379/tcp redis
eeabe57f1f21 mysql:5.7 "docker-entrypoint.s…" 2 週間前 2 週間前 0.0.0.0:3306->3306/tcp, 33060/tcp mysql

docker ps -a を実行してコンテナが作成されたことを確認します

[root@iZ2zeczvvb79boy368xppwZ ~]# docker ps -a
コンテナID イメージ コマンド 作成ステータス ポート名
767829ae1d7c elasticsearch:6.4.0 "/usr/local/bin/dock…" 約 1 分前 終了しました (1) 約 1 分前 elasticsearch
edfc400862eb rabbitmq:3.7.15 "docker-entrypoint.s..." 14 時間前 14 時間前にアップ 0.0.0.0:4369->4369/tcp、0.0.0.0:5671-5672->5671-5672/tcp、0.0.0.0:15671-15672->15671-15672/tcp、0.0.0.0:25672->25672/tcp rabbitmq
2ae2f3f8dc1f nginx:1.10 "nginx -g 'daemon of..." 2 週間前 2 週間前 0.0.0.0:80->80/tcp, 443/tcp nginx
164e4e7561df redis:3.2 "docker-entrypoint.s..." 2 週間前 2 週間前 0.0.0.0:6379->6379/tcp redis
eeabe57f1f21 mysql:5.7 "docker-entrypoint.s…" 2 週間前 2 週間前 0.0.0.0:3306->3306/tcp, 33060/tcp mysql

ログを確認します。docker logs -f elasticsearchコマンドを実行してログを確認し、jvm メモリが不足していることを確認します。

[root@iZ2zeczvvb79boy368xppwZ ~]# docker ログ -f elasticsearch
OpenJDK 64 ビット サーバー VM の警告: オプション UseConcMarkSweepGC はバージョン 9.0 で非推奨となり、将来のリリースで削除される可能性があります。
OpenJDK 64 ビット サーバー VM 警告: INFO: os::commit_memory(0x00007ebf15330000, 549668585472, 0) が失敗しました。エラー = '十分なスペースがありません' (errno = 12)
#
# Java Runtime Environment を続行するにはメモリが不足しています。
# ネイティブ メモリ割り当て (mmap) は、予約済みメモリをコミットするための 549668585472 バイトのマップに失敗しました。
# 詳細情報を含むエラー レポート ファイルは次のように保存されます。
# ログ/hs_err_pid1.log

回避策

jvm.options ファイルの構成を変更する まず、jvm.options ファイルの場所を見つけます (各サーバーの場所は異なる場合があります)

[root@iZ2zeczvvb79boy368xppwZ ~]# find / -name jvm.options
/var/lib/docker/overlay2/d399872a3517b4d4acb0d2f70d0625c0f38251ffe5819a1cea00f8213de3e7f5/diff/usr/share/elasticsearch/config/jvm.options

vimはファイルを入力して仮想マシンの最小メモリを変更します

[root@iZ2zeczvvb79boy368xppwZ ~]# vim /var/lib/docker/overlay2/d399872a3517b4d4acb0d2f70d0625c0f38251ffe5819a1cea00f8213de3e7f5/diff/usr/share/elasticsearch/config/jvm.options

-Xms プロパティを見つけて 512m に変更します (私の elasticsearch:6.4.0 のデフォルトは 1g です)

## JVM 構成

################################################################
## 重要: JVM ヒープサイズ
################################################################
##
## 常に最小および最大のJVMヒープを設定する必要があります
## サイズを同じ値に設定します。たとえば、
## ヒープを 4 GB に設定するには、次のように設定します。
##
## -Xms4g
## -Xmx4g
##
## https://www.elastic.co/guide/en/elasticsearch/reference/current/heap-size.html を参照してください
## 詳細は
##
################################################################

# Xmsはヒープスペース全体の初期サイズを表します
# Xmxはヒープスペース全体の最大サイズを表します

-Xms512m
-Xmx512m

保存して終了

vim では、i を押して編集モードに入り、ESC を押して編集モードを終了し、: を押してコマンド モードに入り、下部のコマンド ラインに w と入力して保存し、q と入力して終了し、q! と入力して強制終了します。
コンテナを再度起動し、docker ps を実行してコンテナが正常に起動したかどうかを確認します。

[root@iZ2zeczvvb79boy368xppwZ ~]# docker ps
コンテナID イメージ コマンド 作成ステータス ポート名
f5c4ed61196b elasticsearch:6.4.0 "/usr/local/bin/dock…" 15 分前 15 分前にアップ 0.0.0.0:9200->9200/tcp、0.0.0.0:9300->9300/tcp elasticsearch
edfc400862eb rabbitmq:3.7.15 "docker-entrypoint.s..." 15 時間前 15 時間前にアップ 0.0.0.0:4369->4369/tcp、0.0.0.0:5671-5672->5671-5672/tcp、0.0.0.0:15671-15672->15671-15672/tcp、0.0.0.0:25672->25672/tcp rabbitmq
2ae2f3f8dc1f nginx:1.10 "nginx -g 'daemon of..." 2 週間前 2 週間前 0.0.0.0:80->80/tcp, 443/tcp nginx
164e4e7561df redis:3.2 "docker-entrypoint.s..." 2 週間前 2 週間前 0.0.0.0:6379->6379/tcp redis
eeabe57f1f21 mysql:5.7 "docker-entrypoint.s…" 2 週間前 2 週間前 0.0.0.0:3306->3306/tcp, 33060/tcp mysql

要約する

これで、docker が elasticsearch を起動するときにメモリ不足になる問題と解決策に関するこの記事は終わりです。docker が elasticsearch を起動するときにメモリ不足になる問題に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • JDKバージョンの問題によりElasticsearchが起動に失敗する問題を解決する
  • Dockerはelasticsearchイメージを起動し、ディレクトリをマウントした後にエラーを解決します
  • DockerがElasticsearch7.xを起動してエラーを報告する問題を解決する
  • elasticsearch 起動時の警告: JVM メモリをロックできません
  • Elasticsearch は guice を通じてノードアセンブリの起動プロセスを挿入します

<<:  フロントエンドフレームワーク Vue における親子コンポーネントデータの双方向バインディングの実装

>>:  MySQLは集計関数を使用して単一のテーブルをクエリします

推薦する

Jenkins の docker-compose デプロイメントと構成に関する詳細なチュートリアル

Docker-compose デプロイメント構成 Jenkins 1. Docker-compose...

Dockerオーバーレイはホスト間のコンテナ相互通信を実現します

目次1. Dockerの設定2. レジストリとネットワークを作成する3. コンテナを起動する環境説明...

...

Linux環境にMySQLデータベースをインストールする詳細なチュートリアル

1. データベースをインストールする1) yum -y install mysql-server (...

Dockerはコンテナ外のコンテナ内でコマンドを実行します

コンテナ内でコマンドを実行したいが、コンテナに入りたくない場合があります。ではどうすればいいでしょう...

MySQL 8.0.16 圧縮版のダウンロードと Win10 システムへのインストール チュートリアル

公式サイトからダウンロード: https://www.mysql.com MySQLの公式サイトにア...

Linux Centos でスクリプトを使用して Docker をインストールする方法

Dockerの主な機能は何ですか?現在、Docker には少なくとも次のアプリケーション シナリオが...

CSSでフレックス配置を表示する(レイアウトツール)

display: flex レイアウトに関しては、深く理解している人もいますし、私も他の人の作業か...

ネイティブ JS カプセル化 vue タブ切り替え効果

この記事の例では、ネイティブJSカプセル化vueタブ切り替えの具体的なコードを参考までに共有していま...

CSS を使用してプログレスバーと順序プログレスバーを実装する例

この半月、期末試験の準備にかなりのエネルギーを費やしました。今日はしっかり復習するべきだったのですが...

html5 の新しいメソッドを使用して JavaScript で要素クラス名を操作する方法の詳細な説明

目次1. classList属性2. 実用化以前の JavaScript では、最初にクラス属性を取...

HTML でスクロールバーを使用する際のヒントを共有する

今日、牛南ニュースリリースシステムについて学んでいたとき、牛南先生はスクロールバーに関するいくつかの...

CSS で div にスクロールを追加し、スクロール バーを非表示にする

CSS は div にスクロールを追加し、スクロール バーを非表示にします。具体的なコードは次のとお...

DockerでRedisをデプロイして起動する方法

DockerでRedisをデプロイするまずLinuxにDockerをインストールし、次にDocker...