[root@compute03 images]# ceph daemon osd.4 config show |grep "mon_max_pg_per_osd" "mon_max_pg_per_osd": "250",
, y/ g$ J! T) D; k( d3 `
这是因为集群 OSD 数量较少,测试过程中建立了多个存储池,每个存储池都要建立一些 PGs 。而目前 Ceph 配置的默认值是每 OSD 上最多有 300 个 PGs 。在测试环境中,为了快速解决这个问题,可以调大集群的关于此选项的告警阀值。方法如下: 在 monitor 节点的 ceph.conf 配置文件中添加: [global].......7 w! u: D A( p G, J: N# f: \
mon_pg_warn_max_per_osd = 1000
" t1 m N! e, m/ ]% \
0 w7 J% }. a& U/ V. t' x$ ]' H6 Q
然后重启 monitor 进程。
% v3 \3 Y7 j% h: B2 |& z9 l V
或者直接用 tell 命令在运行时更改参数的值而不用重启服务: ceph tell mon.* injectargs '--mon_pg_warn_max_per_osd 1000'' `7 m! n4 b8 y- Y
" K7 _) Q% _/ ^2 s# U% K1 O8 N9 G
/ T# l: x. C7 V; W1 V而另一种情况, too few PGs per OSD (16 < min 20) 这样的告警信息则往往出现在集群刚刚建立起来,除了默认的 rbd 存储池,还没建立自己的存储池,再加上 OSD 个数较多,就会出现这个提示信息。这通常不是什么问题,也无需修改配置项,在建立了自己的存储池后,这个告警信息就会消失。 . J+ h. ~. o5 G! g8 c J' t
. x: G6 e2 O {
|