【ETCD】【实操篇(十七)】 etcd 集群定期维护指南

server/2024/12/28 15:21:59/

在这里插入图片描述

目录

      • 概述
      • Raft 日志保留
      • 键空间历史压缩:v3 API 键值数据库
      • 碎片整理
      • 空间配额
      • 快照备份

概述

为了保持 etcd 集群的可靠性,需要定期进行维护。根据 etcd 应用程序的需求,这些维护通常可以自动化进行,并且不会导致停机或性能显著下降。

所有 etcd 维护都涉及管理 etcd 键空间消耗的存储资源。如果无法有效控制键空间大小,存储空间配额将触发集群范围的警报,使系统进入受限操作的维护模式。为了避免键空间耗尽可写入空间,必须对 etcd 键空间历史进行压缩。同时,通过对 etcd 成员进行碎片整理,可以回收存储空间。此外,定期快照备份 etcd 成员状态,有助于在操作错误导致数据丢失或损坏时进行恢复。

Raft 日志保留

--snapshot-count 配置在压缩前要保留在内存中的已应用 Raft 条目数量。当达到 --snapshot-count 时,服务器会先将快照数据持久化到磁盘,然后截断旧的条目。如果一个较慢的跟随者请求的日志在压缩索引之前,领导者会发送快照,强制跟随者覆盖其状态。

较高的 --snapshot-count 会在快照之前保留更多的 Raft 条目,导致更高的内存使用率。然而,由于领导者会保留最新的 Raft 条目更长时间,较慢的跟随者有更多时间赶上快照。

从 v3.2 开始,--snapshot-count 的默认值已从 10,000 改为 100,000。

键空间历史压缩:v3 API 键值数据库

由于 etcd 会保留其键空间的完整历史,因此必须定期压缩历史数据,以避免性能下降和存储空间耗尽。历史压缩会丢弃给定修订版本之前的所有旧键值信息,从而释放存储空间供新数据写入。

  • 手动压缩
    使用 etcdctl 手动触发压缩:
$ etcdctl compact 3
  • 自动压缩
    使用 --auto-compaction-* 选项设置自动压缩周期:
$ etcd --auto-compaction-retention=1

碎片整理

在压缩键空间之后,后端数据库可能会出现内部碎片。这些碎片占据磁盘空间,但无法被主机文件系统直接使用。碎片整理的目的是将这些空间释放回文件系统。

  • 对单个成员进行碎片整理
$ etcdctl defrag
  • 对集群所有端点进行碎片整理
$ etcdctl defrag --cluster

空间配额

etcd 的空间配额确保集群的稳定运行。如果键空间过大,etcd 可能会出现性能问题,甚至耗尽存储空间,导致不可预测的集群行为。

  • 设置空间配额
$ etcd --quota-backend-bytes=$((16*1024*1024))
  • 清理空间超限告警
$ ETCDCTL_API=3 etcdctl compact $rev
$ ETCDCTL_API=3 etcdctl defrag
$ ETCDCTL_API=3 etcdctl alarm disarm

快照备份

定期对 etcd 集群进行快照备份,可作为键空间的持久备份。通过快照,etcd 集群可以恢复到特定的时间点。

  • 创建快照
$ etcdctl snapshot save backup.db
  • 检查快照状态
$ etcdutl --write-out=table snapshot status backup.db

通过以上维护操作,etcd 集群可以保持高可用性和稳定性,同时避免因存储空间不足导致的性能下降或系统故障。


http://www.ppmy.cn/server/153943.html

相关文章

路由器刷机TP-Link tp-link-WDR566 路由器升级宽带速度

何在路由器上设置代理服务器? 如何在路由器上设置代理服务器? 让所有连接到该路由器的设备都能够享受代理服务器的好处是一个不错的选择,特别是当需要访问特定的网站或加速网络连接的时候。下面是一些您可以跟随的步骤,使用路由器…

mongodb给不同的库设置不同的密码进行连接

默认的数据库安装之后是没有密码的,是可以直接访问的,但是如果端口不小心暴露出去了,就会存在很大的安全隐患。本节课教大家如何给mongodb设置账号密码进行访问。 设置管理员并密码登录 查看服务 默认安装好的mongodb会自动创建好服务&…

汇编学习笔记

汇编 1. debug指令 -R命令(register) 查看、改变CPU寄存器的内容 r ax 修改AX中的内容 -D命令(display) 查看内存中的内容 -E命令(enter) 改写内存中的内容 -U命令(unassenble反汇编) 将内存中的机器指令翻译成汇编指令 -T命令(trace跟踪) 执行一条机器指令 -A命令…

GB/T34944-2017 《Java语言源代码漏洞测试规范》解读——安全功能

GB/T34944-2017 《Java语言源代码漏洞测试规范》标准是软件测试实验室开展代码测试活动的重要依据,也是软件测试实验室申请代码测试CNAS/CMA实验室认证时所依据的标准方法。本系列文章一起解读GB/T34944-2017 《Java语言源代码漏洞测试规范》,前面的文章…

使用Python pickle模块进行序列化

使用Python pickle模块进行序列化 在Python中,pickle模块是一个用于实现数据序列化与反序列化的强大工具。与json模块不同的是,pickle支持将几乎所有的Python对象进行序列化,包括字典、列表、类实例,甚至函数。这使得它在处理复杂…

mybatis 缓存

本地缓存 Mybatis 使用到了两种缓存:本地缓存(local cache)和二级缓存(second level cache)。 每当一个新 session 被创建,MyBatis 就会创建一个与之相关联的本地缓存。任何在 session 执行过的查询结果都…

【ComfyUI + 自定义节点】图片叠加掩膜(mask)部分扣掉(变黑)

Comfyui的官方示例:https://github.com/comfyanonymous/ComfyUI/blob/master/custom_nodes/example_node.py.example 一、代码 ( 逻辑:将图片对应掩膜覆盖的区域替换为黑色) 因为comfyui加载的图片后,转化为tensor i…

XDP (eXpress Data Path):在操作系统内核中实现快速、可编程包处理

大家觉得有意义和帮助记得及时关注和点赞!!! 1 引言 1.1 现有方案(kernel bypass)存在的问题1.2 新方案:给内核网络栈添加可编程能力1.3 新方案(XDP)的优点1.4 本文组织结构2 相关工作 2.1 用户态轮询 vs. XDP2.2 内核…