第 4 章 池
Ceph 客户端在池中存储数据。创建池时,您要为客户端创建一个 I/O 接口来存储数据。从 Ceph 客户端的角度来看,即块设备、网关和与 Ceph 存储集群交互非常简单:创建集群处理并连接到集群;然后,创建一个 I/O 上下文来读取和写入对象及其扩展属性。
创建集群处理和连接到集群
要连接到 Ceph 存储集群,Ceph 客户端需要集群名称(默认为 ceph
),以及初始监控地址。Ceph 客户端通常使用 Ceph 配置文件的默认路径检索这些参数,然后从文件读取,但用户也可以在命令行中指定参数。Ceph 客户端还提供用户名和密钥,身份验证默认为 on
。然后,客户端联系 Ceph 监控集群,并检索 cluster map 的最新副本,包括其 monitor、OSD 和池。
创建池 I/O 上下文
若要读取和写入数据,Ceph 客户端会创建一个 I/O 上下文到 Ceph 存储集群中的特定池。如果指定的用户具有池的权限,Ceph 客户端可以从中读取并写入到指定的池。
Ceph 的架构可让存储集群为 Ceph 客户端提供一个简单的接口。客户端可以通过指定池名称并创建 I/O 上下文来选择其中一个定义的复杂的存储策略。存储策略对 Ceph 客户端在所有容量和性能方面不可见。同样,Ceph 客户端的复杂性(如将对象映射到块设备表示或提供 S3 或 Swift RESTful 服务)对 Ceph 存储集群不可见。
池为您提供了:
-
弹性 :您可以设置允许多少 OSD 失败,而不丢失数据。对于复制池,它是对象所需的副本数。典型的配置存储对象和一个额外副本,
大小为 2
,但您可以确定副本数或副本数。对于纠删代码池,它是 纠删代码 profile 中的m=2
的编码区块数量。 - 放置组 :您可以为池设置放置组(PG)的数量。典型的配置使用每个 OSD 大约 50-100 的 PG 来提供最佳平衡,而无需使用太多计算资源。在设置多个池时,请确保为池和整个集群设置合理的 PG 数量。
- CRUSH 规则 :当您在池中存储数据时,映射到池的 CRUSH 规则可让 CRUSH 识别每个对象放置及其副本的规则,或者集群中纠删代码池的区块。您可以为池创建自定义 CRUSH 规则。
-
配额 :当您在
ceph osd pool set-quota
的池上设置配额时,您可以限制在指定池中存储的最大字节数或最大字节数。
4.1. 池和存储策略
要管理池,您可以列出、创建和删除池。您还可以查看各个池的使用情况统计信息。