elasticsearch安全重启

非安全重启面临的问题

在生产环境中,如果直接kill掉节点,可能导致数据丢失、es服务不可用等问题。
另外,集群会认为该节点挂掉了,集群重新分配数据进行数据转移(shard rebalance),会导致节点直接大量传输数据
其次、节点重启之后,恢复数据,同样产生大量的磁盘、网络流量,耗费机器和网络资源的。

安全重启步骤
  1. 暂停数据写入程序
  2. 关闭集群shard allocation
  3. 手动执行POST /_flush/synced
  4. 重启节点
  5. 重新开启集群shard allocation
  6. 等待recovery完成,集群health status变成green
  7. 重新开启数据写入程序
速度调优

可临时增大 max_bytes_per_sec;随后在进行更改
可以多节点同时操作
可以将历史索引的副本数暂时调整为0;集群恢复后在进行调整
使用 _forcemerge

GET _cluster/settings?include_defaults=true

GET _cat/recovery


# 1. 关闭集群自动shard allocation
PUT _cluster/settings 
{ 
  "persistent": { 
    "cluster.routing.allocation.enable": "none"
  }
}

# 手动触发flush数据
POST /flush/synced

# 重启节点

# 增加recovery 速率
PUT _cluster/settings
{
  "transient": 
  {
    "indices.recovery.max_bytes_per_sec": "2000mb"
  }
}
# 恢复recovery 速率
PUT _cluster/settings
{
  "transient": 
  {
    "indices.recovery.max_bytes_per_sec": "null"
  }
}

# 开启集群自动shard allocation
PUT _cluster/settings 
{ 
  "persistent": { 
    "cluster.routing.allocation.enable": "all"
  }
}


GET _cat/recovery?v
{"active_only":true}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值