磁盘配置
目录
存储容量
INFO
请将以下分区挂载到专用磁盘或 LVM 配置的逻辑卷上,以便后续扩展。
推荐的 ETCD 实践
快速存储对 etcd 的可靠运行至关重要。etcd 依赖持久且低延迟的磁盘操作,将提案持久化到其预写日志(WAL)。
如果磁盘写入耗时过长,fsync 延迟可能导致成员错过心跳,无法及时提交提案,并出现请求超时或临时领导者变更。这些问题还会降低 Kubernetes API 的响应速度,影响整个集群的响应性能。
总之,HDD 是不理想的选择,不推荐使用。如果必须使用 HDD,请选择最快的型号(例如 15,000 RPM)。
INFO
以下硬盘实践可提供最佳的 etcd 性能:
-
优先选择 SSD 或 NVMe 作为 etcd 磁盘。当写入耐久性和稳定性是重点时,考虑服务器级单层单元(SLC)SSD。避免使用 NAS、SAN 和 HDD。
- 优先选择写入吞吐量高的磁盘,以加快压缩和碎片整理。
- 优先选择读取带宽强的磁盘,以缩短故障恢复时间。
- 优先选择延迟稳定且低的磁盘,确保快速的读写操作。
-
避免使用分布式块存储系统,如 Ceph RADOS Block Device (RBD)、网络文件系统 (NFS) 及其他网络附加存储,因为它们会引入不可预测的延迟。
-
将 etcd 数据放在专用磁盘或专用逻辑卷上。
- 不要在控制平面主机上放置 I/O 敏感(如日志)或其他高强度文件系统活动,或至少不要让它们与 etcd 共享相同的底层存储。
-
持续使用
fio等工具进行基准测试,并利用结果跟踪集群增长过程中的性能。详情请参阅 磁盘基准测试指南。
验证 etcd 硬件规格
使用 fio 进行基准测试
为了测量实际的顺序 IOPS 和吞吐量,建议使用磁盘基准测试工具 fio。您可以参考以下操作说明:
WARNING
请勿在任何 集群节点上运行这些测试。
请在与控制平面节点配置相同的专用虚拟机上运行测试。\