当前位置: 首页 > news >正文

etcd资源超额

集群内apiserver一直重启,重启kubelet服务后查看日志发现一下报错:

Error from server: etcdserver: mvcc: database space exceeded

报错原因:

  • etcd服务未设置自动压缩参数(auto-compact)
  • etcd 默认不会自动 compact,需要设置启动参数,或者通过命令进行compact,如果变更频繁建议设置,否则会导致空间和内存的浪费以及错误。Etcd v3 的默认的 backend quota 2GB,如果不 compact,boltdb 文件大小超过这个限制后,就会报错:”Error: etcdserver: mvcc: database space exceeded”,导致数据无法写入。

处理过程:

1、查询是否为超额(DB SIZE超过2G会导致集群不可用)

ETCDCTL_API=3 etcdctl --write-out=table endpoint status

  查看告警

ETCDCTL_API=3 etcdctl alarm list

2、获取版本号(以下为基于主机部署的etcd,集群内etcd执行命令时需去掉--endpoints='*:2379'参数)

[root@etcd]# export ETCDCTL_API=3   #使用 api version 3
[root@etcd]# rev=$(etcdctl --cacert=/etc/kubernetes/ssl/ca.pem \
--cert=/etc/etcd/ssl/etcd.pem \ 
--key=/etc/etcd/ssl/etcd-key.pem \ 
--endpoints="https://127.0.0.1:2379" \
endpoint status --write-out="json" \ 
| egrep -o '"revision":[0-9]*' \ 
| egrep -o '[0-9].*') 

如部署时使用了http协议,不需要添加证书

3、整理碎片并解除告警

#整合压缩旧版本数据
[root@etcd]# etcdctl --cacert=/etc/kubernetes/ssl/ca.pem --cert=/etc/etcd/ssl/etcd.pem --key=/etc/etcd/ssl/etcd-key.pem --endpoints="http://21.101.12.11:2379" compact $rev#执行碎片整理
[root@etcd]# etcdctl --cacert=/etc/kubernetes/ssl/ca.pem --cert=/etc/etcd/ssl/etcd.pem --key=/etc/etcd/ssl/etcd-key.pem --endpoints="http://21.101.12.11:2379" defrag #解除告警
[root@etcd]# etcdctl --cacert=/etc/kubernetes/ssl/ca.pem --cert=/etc/etcd/ssl/etcd.pem --key=/etc/etcd/ssl/etcd-key.pem --endpoints="http://21.101.12.11:2379" alarm disarm#查看告警
[root@etcd]# etcdctl --cacert=/etc/kubernetes/ssl/ca.pem --cert=/etc/etcd/ssl/etcd.pem --key=/etc/etcd/ssl/etcd-key.pem --endpoints="http://21.101.12.11:2379" alarm list 

http://www.lryc.cn/news/498471.html

相关文章:

  • AndroidStudio-常见界面控件
  • 网络协议(TCP/IP模型)
  • python 清华pip镜像源报HTTP error 403
  • swift 屏幕录制
  • 通过精密时间协议(PTP)对计算机网络中的多个设备进行时间同步
  • Docker 安装系列
  • 使用springboot-3.4.1搭建一个netty服务并且WebSocket消息通知(适用于设备直连操作,以及回复操作)
  • 4. 设计模式分类
  • Hive分区值的插入
  • 【多个图片合并成PDF】
  • Flutter动画(三)内建显式动画Widget
  • 本地运行打包好的dist
  • 什么是Layer Normalization?
  • 17. Threejs案例-Three.js创建多个立方体
  • RK3568 Android14 打开蓝牙时默认同意
  • 多模态视频大模型Aria在Docker部署
  • Ant-Design-Vue 全屏下拉日期框无法显示,能显示后小屏又位置错乱
  • AMR移动机器人赋能制造业仓储自动化升级
  • 【PHP项目实战】活动报名系统
  • 【HarmonyOS】Component组件引入报错 does not meet UI component syntax.
  • vue3项目最新eslint9+prettier+husky+stylelint+vscode配置
  • 备赛蓝桥杯--算法题目(3)
  • CSS中要注意的样式效果
  • 【NIPS2024】Unique3D:从单张图像高效生成高质量的3D网格
  • 使用Kubernetes部署Spring Boot项目
  • 基于VTX356语音识别合成芯片的智能语音交互闹钟方案
  • git将一个项目的文件放到另一个项目的文件夹下
  • Cannon.js 从入门到精通
  • 深入理解 TCP 标志位(TCP Flags)
  • K8S,StatefulSet