1.1 查询系统中全部的pool算法
命令格式: 后端
ceph osd lspools 或rados lspools
1.2 建立pool安全
(1) 指定pg数目、pgp数目等建立pool性能
命令格式:ui
ceph osd pool create <poolname>{pg-num}{pgp-num} {replicated|erasure} {<erasure_code_profile>} {<ruleset>}
命令含义:spa
Pool分为replicated pool和erasure code pool,replicate pool以多副本的方式提供数据备份,EC pool使用纠删码方式提供数据安全code
建立erasure pool还能够指定erasure_code_profile,erasure_code_profile 使用命令osd erasure-code-profile set指定,erasure-code-profile参数含义:内存
directory=<dir> \ # plugin directory absolute pathci
plugin=jerasure \ # plugin name (only jerasure)rem
k=<k> \ # data chunks (default 2)
m=<m> \ # coding chunks (default 2)
technique=<technique> \ # coding technique
Jerasure 是多种Erasure Coding算法的一个开源库,采用C/C++实现,活跃很高,且使用广,technique可选项:reed_sol_van, reed_sol_r6_op, cauchy_orig, cauchy_good, liberation, blaum_roth and liber8tion.
每一个pg占用必定内存和CPU、且PG数目的增长会增长peer数目,所以每一个pool配置的PG数目有必定的限制,不然会影响整个集群的性能,每一个pool大概须要的PG数目为:
(OSDs * 100)
Total PGs = ------------
OSD per object
OSD per object对于replicated pool来讲为副本数,对于EC pool来讲是k+m
(2) 指定uid建立pool
命令格式:
mkpool <pool-name> [123[ 4]]
命令含义:
建立pool,其拥有者uid为123,crush rule为4
1.3 修改pool参数
命令格式:
ceph osd pool set {pool-name} {key} {value}
命令含义:
Key值含义:
Size:pool副本数
min_size:pool最小副本数,当pool中object副本数小于min_size, object将中止接收I/O
crash_replay_interval: PG修复期间,运行客户端重放请求而不提交时间间隔(单位s,默认45s)
pgp_num:使用pgp_num计算pg id
crush_ruleset:pool使用的crush rule_id,ceph osd crush rule dump可查询全部配置的策略
auid:设置pool归属用户id
hit_set_type: cache命中跟踪类型设置,默认为bloom,其余的类型包括explicit_hash、explicit_object
hit_set_period:
hit_set_count:
hit_set_ fpp:bloom误检率
cache_target_dirty_ratio:默认.4,当cache脏数据到达40%,将脏数据刷到后端pool中
cache_target_full_ratio:默认.8,d当cache中数据量到达80%,将cache中冷数据删除
target_max_bytes:cache pool最大容量
target_max_objects:cache pool最大存储的object数目
cache_min_flush_age: object刷到后端pool的最小年龄,单位为s
cache_min_evict_age:object从cache中删除的最小年龄,单位为s
1.4 查询pool参数
命令格式:
osd pool get <poolname> size|min_size| crash_replay_interval|pg_num|pgp_num| crush_ruleset| hit_set_type|hit_set_period|hit_set_count|hit_set_fpp|auid|target_max_objects|target_max_bytes| cache_target_dirty_ratio|cache_target_full_ratio|cache_min_flush_age|cache_min_evict_age|erasure_code_profile 或者使用ceph osd dump |grep pool显示全部pool的参数
1.5 删除pool
命令格式:
ceph osd pool delete {pool-name} [{pool-name} \ [-yes-i-really-really-mean-it] 或 rados rmpool <pool-name> [<pool-name> --yes-i-really-really-mean-it]
命令含义:
删除pool,当pool有数据或者配置了用户等信息,须要将这些信息手动删除掉,不然强制删除后这些信息还会在
1.6 重命名pool
命令格式:
ceph osd pool rename {current-pool-name} {new-pool-name}
1.7 查询pool配额
命令格式:
ceph osd pool get-quota <poolname>
命令含义:
查询pool容量和最大object数目
1.8 设置pool配额
命令格式:
ceph osd pool set-quota <poolname> max_objects|max_bytes <val>
命令含义:
设置pool容量和最大object数目
1.9 查询pool属性
命令格式:
ceph osd pool stats {<poolname>}
1.10 建立pool快照
命令格式:
ceph osd pool mksnap <poolname> <snapname> 该命令等同于: rados mksnap <snapname> -p <poolname>
命令含义: 对pool中全部的object作快照
1.11 查询pool快照
命令格式:
rados lssnap –p <poolname>
命令含义:
查询pool快照
1.12 pool快照回滚
命令格式:
rados rollback <obj-name> <snap-name> -p < poolname >
命令含义:目前只能针对pool中某个object进行回滚,不能整个pool回滚,咱们能够考虑本身实现下?
1.13 cache pool配置和删除
(1) 将一个pool配置为另一个pool cache命令:
ceph osd tier add <poolname> <cachepoolname> 或 osd tier add-cache <poolname> <cachepoolname> [cachepoolname size
(2) 设置cache pool模式:
ceph osd pool set <cachepoolname> cache-mode <val>
<val>一共有4个:
‘none’, ‘writeback’, ‘forward’, and ‘readonly’
‘writeback’和‘readonly’见2.3节
‘forward’将cache pool关闭以前,须要将cache pool模式改成’ forward’,不接收客户端的IO后,才将cache pool数据刷到后端pool
(3) 若是将cache pool工做模式设置为writeback‘,须要执行下面命令
Cache pool才能工做,目的将I/O映射到cache pool中
ceph osd tier set-overlay <poolname> <cachepoolname>
(4)将cache pool数据刷到后端pool
rados -p {cachepool} cache-flush-evict-all
(5)解除cache pool和后端pool对应关系
ceph osd tier remove-overlay <cachepoolname> ceph osd tier remove <poolname> <cachepoolname>