第 2 章 池概述


Ceph 客户端在池中存储数据。在创建池时,您要为客户端创建一个 I/O 接口来存储数据。

从 Ceph 客户端的角度来看,即块设备、网关和静态,与 Ceph 存储集群交互非常简单:

  • 创建集群句柄。
  • 将集群句柄连接到集群。
  • 创建用于读取和写入对象及其扩展属性的 I/O 上下文。

创建集群句柄并连接到集群

要连接 Ceph 存储集群,Ceph 客户端需要以下详细信息:

  • 集群名称(默认情况下 Ceph )不使用,因为它声音是模糊的。
  • 初始监控地址。

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

创建处理

创建池 I/O 上下文

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

I/O 上下文

Ceph 的架构使存储集群能够向 Ceph 客户端提供这种显著简单的接口,以便客户端可以通过指定池名称并创建 I/O 上下文来选择您定义的一个复杂存储策略。存储策略对于 Ceph 客户端而言都不可见,但容量和性能都不可见。同样,Ceph 客户端的复杂性(如将对象映射到块设备表示或提供 S3/Swift RESTful 服务)对 Ceph 存储集群不可见。

池为您提供了弹性、放置组、CRUSH 规则和配额。

  • 弹性 :您可以设置允许多少 OSD 在不丢失数据的情况下失败。对于复制池,它是对象的副本数或副本。典型的配置存储一个对象和一个附加副本,即 size = 2,但您可以确定副本或副本数。对于纠删代码池,这是编码区块的数量,即 纠删代码 profile 中的 m=2
  • 放置组 :您可以为池设置放置组数量。典型的配置使用每个 OSD 大约 50-100 放置组来提供最佳平衡,而无需使用太多的计算资源。在设置多个池时,要小心,请务必为池和集群设置合理的放置组数量。
  • CRUSH 规则 :当您在池中存储数据时,映射到池的 CRUSH 规则可让 CRUSH 识别每个对象及其副本放置的规则,或用于纠删代码池的区块。您可以为池创建自定义 CRUSH 规则。
  • 配额 :当使用 ceph osd pool set-quota 命令在池中设置配额时,您可以限制在指定池中存储的最大字节数或最大字节数。
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.