获取指定 ceph pool上 PG 分布

1 篇文章 0 订阅

前言

尽管ceph可以提供出多个pool,很多情况下,客户的所有的业务数据位于一个pool内。这种情况下,主要使用的pool的PG分布是否均匀,就决定了各个OSD的使用是否均匀。

CRUSH算法让PG均匀地分布在各个OSD上,但这仅仅是概率上的平均,实际使用中,经常发生不均匀的情况,甚至出现非常不均匀的情况。

我们以pg_num = 1024的双副本pool为例,对于该pool,一共有2048个PG,这2048个PG分布在OSD上。如果Pool中有10个OSD,那么平均每个OSD应该分到204~205个PG,但是CRUSH算法不是round-robin,无法做到这么平均。

如果OSD.X分到最多的PG,240个,而OSD.Y分到最少的PG 180个,那么会有更多的数据写入OSD.X,这种现象对带来两个弊端:

* 业务压力并不平衡,极端情况下,因为OSD.X先到性能瓶颈而影响整个集群的性能

* 长此以往,磁盘使用率不均匀,当OSD.X使用率到达95%而不能再写入时,OSD.Y的使用率才到71%

因此,知道Pool上PG在OSD上的分布,在不均匀的情况下采取必要措施是十分必要的

获取Pool上PG分布

  • 获取OSDMap
ceph osd getmap -o om

  •  获取crushmap
ceph osd getcrushmap -o cm 
或者
osdmaptool om --export-crush cm

  • 获取指定pool上PG 的分布
osdmaptool om --import-crush cm --test-map-pgs --pool 5

   下面以一个实际中的pool为例,查看PG在OSD的分布情况

不难看出,PG分布的比较不均匀,但总体上来说还好,osd.4上的PG数最多 348个PG,而osd.3上PG数最少,只有326,平均下来,osd.4的负载要比osd.3的重,如果不同OSD之间使用量差距很大就需要引起注意

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qin147896325

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值