当前位置:   article > 正文

elasticsearch安全重启_es重启会丢失数据吗

es重启会丢失数据吗
非安全重启面临的问题

在生产环境中,如果直接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}


  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/508025
推荐阅读
相关标签
  

闽ICP备14008679号