ElasticSearch 小版本 RPM 滚动升级(如 7.14.0 → 7.17.10,无服务中断)

小版本升级(同一系列内)无破坏性变更,支持逐个节点滚动升级,集群整体服务不中断,步骤如下:

步骤 1:单个节点禁用分片分配(减少资源消耗)

登录待升级节点,执行命令禁止分片迁移:

bash 复制代码
curl -XPUT "http://<当前节点IP>:9200/_cluster/settings" -H "Content-Type: application/json" -d '{
    "persistent": {
        "cluster.routing.allocation.enable": "none"
        }
}'

步骤 2:停止当前节点的 Elasticsearch 系统服务

RPM 安装的 ES 以 systemd 管理,停止服务命令:

bash 复制代码
# 停止 ES 服务
systemctl stop elasticsearch.service

# 验证服务已停止
systemctl status elasticsearch.service

步骤 3:使用 YUM 升级当前节点的 Elasticsearch RPM 包

直接通过 yum update 升级(自动匹配 YUM 仓库中的最新小版本):

bash 复制代码
# 升级 Elasticsearch(仅升级该包,不升级其他依赖)
yum update elasticsearch -y

说明:YUM 会自动保留原有配置文件(/etc/elasticsearch),并将新版本配置文件以 .rpmnew 后缀留存(若有差异),无需手动替换二进制文件。

步骤 4:修复权限(RPM 升级后可能重置权限)

确保 ES 相关目录的所属用户仍为 elasticsearch(RPM 默认创建该用户):

bash 复制代码
chown -R elasticsearch:elasticsearch /etc/elasticsearch
chown -R elasticsearch:elasticsearch /var/lib/elasticsearch
chown -R elasticsearch:elasticsearch /var/log/elasticsearch

步骤 5:重新加载 systemd 配置,启动 ES 服务

bash 复制代码
# 重新加载 systemd 配置(防止服务文件变更)
systemctl daemon-reload

# 启动 ES 服务
systemctl start elasticsearch.service

# 设置开机自启(保持原有配置)
systemctl enable elasticsearch.service

# 验证服务启动成功
systemctl status elasticsearch.service

步骤 6:验证节点状态,启用分片分配

  1. 验证节点是否正常加入集群,版本是否更新:
bash 复制代码
curl -XGET "http://<当前节点IP>:9200/_nodes/version?pretty"
  1. 启用分片分配,等待分片同步完成(集群回到 green 状态):bash运行
bash 复制代码
curl -XPUT "http://<当前节点IP>:9200/_cluster/settings" -H "Content-Type: application/json" -d '{
  "persistent": {
    "cluster.routing.allocation.enable": "all"
  }
}'

# 等待集群恢复 green,超时 5 分钟
curl -XGET "http://<当前节点IP>:9200/_cluster/health?wait_for_status=green&timeout=300s&pretty"

步骤 7:重复步骤 1-6,升级集群中所有其他节点

逐个节点完成滚动升级,确保所有节点最终版本一致,升级完成后再次全局检查集群健康和版本一致性。

相关推荐
java-yi4 小时前
Elasticsearch(ES)核心用法与实战技巧分享
大数据·elasticsearch·搜索引擎
星辰_mya5 小时前
Es之脑裂
大数据·elasticsearch·搜索引擎
历程里程碑8 小时前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask
闲人编程1 天前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
先跑起来再说1 天前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
Dxy12393102161 天前
深度解析 Elasticsearch:从倒排索引到 DSL 查询的实战突围
大数据·elasticsearch·搜索引擎
Dxy12393102161 天前
别再让 ES 把你拖垮!5 个实战技巧让搜索性能提升 10 倍
大数据·elasticsearch·搜索引擎
星辰_mya1 天前
Elasticsearch线上问题之OOM
大数据·elasticsearch·搜索引擎
Elastic 中国社区官方博客1 天前
使用 Groq 与 Elasticsearch 进行智能查询
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
张彦峰ZYF1 天前
一套「策略化 Elasticsearch 召回平台」架构设计思路
大数据·elasticsearch·搜索引擎