第 4 章 池


Ceph 客户端在池中存储数据。创建池时,您要为客户端创建一个 I/O 接口来存储数据。从 Ceph 客户端的角度来看,即块设备、网关和与 Ceph 存储集群交互非常简单:创建集群处理并连接到集群;然后,创建一个 I/O 上下文来读取和写入对象及其扩展属性。

创建集群处理和连接到集群

要连接到 Ceph 存储集群,Ceph 客户端需要集群名称(默认为 ceph ),以及初始监控地址。Ceph 客户端通常使用 Ceph 配置文件的默认路径检索这些参数,然后从文件读取,但用户也可以在命令行中指定参数。Ceph 客户端还提供用户名和密钥,身份验证默认为 on。然后,客户端联系 Ceph 监控集群,并检索 cluster map 的最新副本,包括其 monitor、OSD 和池。

创建 Handle

创建池 I/O 上下文

若要读取和写入数据,Ceph 客户端会创建一个 I/O 上下文到 Ceph 存储集群中的特定池。如果指定的用户具有池的权限,Ceph 客户端可以从中读取并写入到指定的池。

I/O 上下文

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. 池和存储策略

要管理池,您可以列出、创建和删除池。您还可以查看各个池的使用情况统计信息。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.