Docker启动Elasticsearch失败原因及解决方法

问题出现原因

查看容器日志,发现是配置文件格式错误,但是又进不了容器里面修改【Elasticsearch容器已经起不来了】

解决方法

在根目录下查找Elasticsearch配置文件并修改

# 进入根目录
cd /
# 查找配置文件
find ./ -name elasticsearch.yml
./data/docker/overlay2/f1e9db02df0d207a009e727b6be64e68e38e572cf7991d5b9b27d2b1c32cc68b/diff/usr/share/elasticsearch/config/elasticsearch.yml
# 使用vim命令修改正确的格式
vim ./data/docker/overlay2/f1e9db02df0d207a009e727b6be64e68e38e572cf7991d5b9b27d2b1c32cc68b/diff/usr/share/elasticsearch/config/elasticsearch.yml

修改正确后启动容器即可。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果在 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 的内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值