记录docker启动elasticsearch时内存不足问题及解决方法

腾讯云服务器docker部署es,容器状态一直为restarting, docker logs 容器id --> 查看容器日志,显示报错

OpenJDK 64-Bit Server VM warning: INFO: os::commit_memory(0x00007ebf15330000, 549668585472, 0) failed; error='Not enough space' (errno=12)

解决方法

1.查找jvm.options文件位置(每个服务器的位置可能不同)
2.修改jvm.options文件配置
在这里插入图片描述
在这里插入图片描述
找到-Xms属性,这里默认是1g,我改成256m,wq保存退出

保存并退出

vim中按i进入编辑模式,按ESC退出编辑模式,按:进入命令模式,然后在底部命令行输入w为保存,q为退出,q!为强制退出。

重启容器后测试
在这里插入图片描述
解决参考

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果在 Docker 容器启动 Elasticsearch 8.7.1 后无法访问,可能是由于以下原因导致的: 1. 端口映射问题:在 docker-compose.yml 文件中,Elasticsearch 容器的 9200 和 9300 端口映射到了主机的同名端口。如果这些端口已经被其他进程占用,Elasticsearch 就无法使用这些端口。可以尝试修改映射端口,或者停止占用这些端口的进程。 2. 内存不足问题Elasticsearch 需要占用一定的内存来运行,如果内存不足Elasticsearch 就无法正常启动。可以尝试增加 Docker 容器的内存限制,或者使用更高配置的服务器。 3. 配置文件问题Elasticsearch 的配置文件可能存在错误或不完整,导致无法启动或无法正常工作。可以尝试检查配置文件,或者使用默认配置文件。 对应的解决方法: 1. 修改映射端口:在 docker-compose.yml 文件中,将 Elasticsearch 容器的 9200 和 9300 端口映射到其他未被占用的端口。 2. 增加内存限制:在 docker-compose.yml 文件中,增加 Elasticsearch 容器的内存限制,例如将内存限制设置为 2GB: ``` elasticsearch: ... mem_limit: 2g ``` 3. 检查配置文件:可以尝试检查 Elasticsearch 的配置文件,例如 elasticsearch.yml 文件是否存在、是否有必填项缺失等。如果无法解决问题,可以尝试使用默认配置文件。可以在 docker-compose.yml 文件中添加以下内容来使用默认配置文件: ``` elasticsearch: ... volumes: - ./config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml:ro ``` 将上面的配置添加到 docker-compose.yml 文件后,需要在同级目录下创建一个名为 config 的文件夹,并在其中创建一个名为 elasticsearch.yml 的文件。这个 elasticsearch.yml 文件将被用作 Elasticsearch 的配置文件。可以使用 Elasticsearch 官方文档提供的默认配置文件作为 elasticsearch.yml 的内容。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值