> /root/setenv echo "export ES_MAX_MEM = -6ren">
gpt4 book ai didi

ElasticSearch 反复崩溃 "HeapDumpOnOutOfMemoryError"尽管有 4GB ES_MAX_MEM

转载 作者:行者123 更新时间:2023-11-29 02:55:20 26 4
gpt4 key购买 nike

我通过以下方式启动 ElasticSearch

echo "export ES_HEAP_SIZE = 4096" >> /root/setenv
echo "export ES_MAX_MEM = 4096" >> /root/setenv
echo "export ES_MAX_MEM = 4096" >> /root/setenv

# finally, we can start the app
echo 'Starting ElasticSearch...'
bin/elasticsearch -Xmx4g -Xms4g

然而,在根本没有时间(20 分钟)之后,它变得没有响应,显然是由于 HeapDumpOnOutOfMemoryError...

[root@ip-***** api]# ps -ax | grep elasticsearch
6225 ? SLl 5:35 java -Xms256m -Xmx1g -Xss256k -Djava.awt.headless=true -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -XX:+HeapDumpOnOutOfMemoryError -Delasticsearch -Des.path.home=/root/elasticsearch/elasticsearch-0.20.3 -cp :/root/elasticsearch/elasticsearch-0.20.3/lib/elasticsearch-0.20.3.jar:/root/elasticsearch/elasticsearch-0.20.3/lib/*:/root/elasticsearch/elasticsearch-0.20.3/lib/sigar/* -Xmx4g -Xms4g org.elasticsearch.bootstrap.ElasticSearch

编辑——我刚刚注意到此处输出的 -Xms 大小仅为 256m,尽管在上面的启动中传递了 4g。我是不是误会了什么?

FWIW,我在运行 CentOS 和 Java v1.6.0_14-b08 的 Amazon EC2(m1.large 实例 => 8GB RAM)上

最佳答案

首先,设置 ES_HEAP_SIZE 本身并不能帮助您防止内存不足错误。 Elasticsearch 使用的内存量取决于您执行的查询类型:是否使用分面、排序、过滤、有多少字段、这些字段有多大、它们的基数是多少等。

其次,最好使用 ES_INCLUDE脚本,或 service wrapper ,而不是将命令行上需要的所有选项传递给 elasticsearch 脚本。

第三,当您正确设置了ES_HEAP_SIZE 环境变量时,您不需要将-X 选项传递给elasticsearch 脚本.事实上,这些选项没有任何作用——脚本不会将它们传递给 Java。使用 ES_HEAP_SIZE 变量来控制内存,并使用 ES_JAVA_OPTIONS 来控制您要传递给 Java 的其他变量。

关于ElasticSearch 反复崩溃 "HeapDumpOnOutOfMemoryError"尽管有 4GB ES_MAX_MEM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14714036/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com