Elasticsearch启动后自动退出

在练习Elasticsearch (ES) 过程中,由于频繁强制关闭虚拟机导致ES启动失败,主要表现为无法读取或升级本地状态,特别是movie_index索引的元数据丢失。解决方法是对测试环境采取暴力手段,删除ES的数据目录重新启动。在生产环境中,需深入调查元数据映射问题以避免数据丢失。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自己在练习ES的过程中,会经常关闭虚拟机,经常直接退出ES,所以会遇到各种启动失败的问题

每次遇到问题,就去查看log文件,进行排查

通过查看elasticsearch/logs/****.log文件

[ERROR][o.e.g.GatewayMetaState ] [node-02] failed to read or upgrade local state, exiting…
java.io.IOException: failed to find metadata for existing index movie_index [location: 2KBq-ngMS4-eU5OUJ_yQHg, generation: 17]
at org.elasticsearch.gateway.MetaStateService.loadFullState(MetaStateService.java:99) ~[elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.gateway.GatewayMetaState.upgradeMetaData(GatewayMetaState.java:148) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.gateway.GatewayMetaState.(GatewayMetaState.java:102) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.node.Node.(Node.java:473) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.node.Node.(Node.java:251) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Bootstrap$5.(Bootstrap.java:211) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:211) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:325) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:159) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:150) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.cli.EnvironmentAwareCommand.execute(EnvironmentAwareCommand.java:86) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:124) [elasticsearch-cli-7.0.1.jar:7.0.1]
at org.elasticsearch.cli.Command.main(Command.java:90) [elasticsearch-cli-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:115) [elasticsearch-7.0.1.jar:7.0.1]
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:92) [elasticsearch-7.0.1.jar:7.0.1]

可以看到报错内容,为读取或更新本地状态失败,查找已存在的movie_index索引的元数据metadata失败

说明,在强制退出的时候,索引和元数据的映射出了问题

因为自己的是测试环境,所以就暴力解决了,找到存放元数据metadata的位置,直接暴力删除

找到ES安装目录下的data目录,然后删除目录下的nodes文件夹

再重启ES即可

如果是生产环境的话,就要去深究元数据metadata的映射问题了,这里因为没有深究,所以暂时就不讨论了。。。

### Elasticsearch Docker 容器启动自动退出的原因及解决方案 当遇到Elasticsearch Docker容器启动后立即退出的情况时,通常是因为配置不当或资源不足引起的。具体原因可能涉及内核参数设置不正确、内存分配不合理等问题。 #### 1. 调整 `vm.max_map_count` 参数 如果日志显示类似 `max_map_count [65530] is too low` 的错误信息,则表明当前系统的最大映射计数过低[^4]。此时应调整该参数至更高数值: ```bash sysctl -w vm.max_map_count=262144 ``` 此命令会临时修改系统内核参数,在大多数情况下可以解决问题。为了使更改永久生效,可以在 `/etc/sysctl.conf` 文件中添加如下行: ```text vm.max_map_count=262144 ``` 之后执行 `sysctl -p` 命令加载新的配置文件即可。 #### 2. 修改 JVM 内存选项 有时由于默认JVM堆大小不合适也会导致服务无法正常启动。可以通过环境变量来指定更合理的初始和最大堆尺寸。例如: ```bash docker run -d \ -e ES_JAVA_OPTS="-Xms256m -Xmx256m" \ -p 9200:9200 -p 9300:9300 \ --name es7 elasticsearch:7.6.2 ``` 这里设置了最小和最大Java堆分别为256MB,适用于小型集群测试场景;生产环境中建议根据实际情况适当增加这些值[^5]。 #### 3. 使用 `-it` 和 `-d` 组合方式运行容器 为了让容器保持长时间在线状态而不轻易终止,可以选择以交互模式并附加守护进程的方式启动容器: ```bash docker run -dit --name my-es-container docker.elastic.co/elasticsearch/elasticsearch:5.6.16 /bin/bash ``` 这种方式下即使前台终端关闭也不会影响到后台正在运行的服务程序[^3]。 通过上述措施应该能够有效防止Elasticsearch实例频繁崩溃重启的现象发生。当然实际操作过程中还需要密切监控应用性能表现以及硬件资源配置情况,必要时做出相应优化调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值