5.9. bucket 粒度同步策略
现在支持以下功能:
- greenfield 部署 :此发行版本支持新的多站点部署。要设置存储桶粒度同步复制,必须至少配置一个新的 zonegroup/zone。
- brownfield 部署 :将 Ceph 对象网关多站点复制配置迁移到新功能的 Ceph 对象网关 bucket 粒度同步策略复制。
在升级过程中,确保存储集群中的所有节点都处于相同的模式。
- 数据流 - 方向、对称 :可以配置双向/双向复制。
在这个发行版本中,不支持以下功能:
- 源过滤器
- Storage class
- 目标所有者翻译
- 用户模式
当 bucket 或 zonegroup 的同步策略时,从 disabled
变为 enabled
状态,会看到以下行为更改:
正常情况 :
- zonegroup 级别:当同步策略被禁用后,当它被启用时会写入数据,无需额外的步骤。
bucket 级别:当 禁用 同步策略时,当启用 策略时不会捕获数据。在这种情况下,可以应用以下两个临时解决方案之一:
- 将新数据写入存储桶会重新同步旧数据。
-
执行
bucket sync run
命令同步所有旧数据。
当您要从 sync 策略切换到旧策略时,您需要首先运行 sync init
命令,然后运行 radosgw-admin bucket sync run
命令来同步所有对象。
重新划分场景 :
-
zonegroup level:策略
被禁用
时发生的任何 reshard,在策略再次启用后同步都会卡住。此时新对象也不会同步。运行
bucket sync run
命令作为临时解决方案。 -
bucket 级别:如果在策略
被禁用时
重新划分任何存储桶,则同步会在策略再次启用后卡住。此时新对象也不会同步。运行bucket sync run
命令作为临时解决方案。
当为 zonegroup 设置为 enabled
且策略设置为 enabled
或 allowed
为存储桶时,管道配置会从 zonegroup 级别而不是存储桶级别生效。这是一个已知问题 BZ#2240719。
5.9.1. 为 zonegroups 设置双向策略
zonegroup 同步策略使用新的同步策略引擎创建。对 zonegroup 同步策略的任何更改都需要一个 period 更新和提交。
在以下示例中,创建一个组策略,并定义一个数据流,以将数据从一个区移动到另一个区域。为 zonegroups 配置管道,以定义可以使用此数据流的存储桶。以下示例中的系统包括 3 个区域: us-east (master zone)、us-west、us-west-2。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
流程
创建一个新的同步组,状态设置为 允许。
Example
[ceph: root@host01 /]# radosgw-admin sync group create --group-id=group1 --status=allowed
注意在创建完全配置的 zonegroup 复制策略前,建议将-- status 设置为
允许的
,以防止复制启动。为新创建的组创建一个流策略,并将 --flow-type 设为
symmetrical
,以启用双向复制。Example
[ceph: root@host01 /]# radosgw-admin sync group flow create --group-id=group1 \ --flow-id=flow-mirror --flow-type=symmetrical \ --zones=us-east,us-west
创建名为
pipe
的新管道。Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --group-id=group1 \ --pipe-id=pipe1 --source-zones='*' \ --source-bucket='*' --dest-zones='*' \ --dest-bucket='*'
注意对于区,使用 * 通配符来包括前面流策略中设置的所有区域,为存储桶在区中复制所有现有存储桶。
配置存储桶同步策略后,将-- status 设置为 enabled。
Example
[ceph: root@host01 /]# radosgw-admin sync group modify --group-id=group1 --status=enabled
更新并提交新周期。
Example
[ceph: root@host01 /]# radosgw-admin period update --commit
注意对于 zonegroup 策略,需要更新并提交周期。
可选:检查特定存储桶的同步源和目的地。区域中的所有存储桶 us-east 和 us-west 都以双向方式复制。
Example
[ceph: root@host01 /]# radosgw-admin sync info -bucket buck { "sources": [ { "id": "pipe1", "source": { "zone": "us-east", "bucket": "buck:115b12b3-....4409.1" }, "dest": { "zone": "us-west", "bucket": "buck:115b12b3-....4409.1" }, ... } ], "dests": [ { "id": "pipe1", "source": { "zone": "us-west", "bucket": "buck:115b12b3-....4409.1" }, "dest": { "zone": "us-east", "bucket": "buck:115b12b3-....4409.1" }, ... } ], ... }
以上输出中的 id 字段反映了生成该条目的管道规则。单个规则可以生成多个同步条目,如下例所示。
5.9.2. 为 zonegroups 设置方向策略
使用同步策略引擎,设置 zone group 的策略。
在以下示例中,创建组策略并配置数据流,以将数据从一个区域移动到另一个区域。另外,为 zonegroups 配置管道,以定义可以使用此数据流的存储桶。以下示例中的系统包括 3 个区域: us-east
(主区域)、us-west
(secondary zone)和 us-west-2
(backup zone)。在这里,us-west-2
是 us-west
的副本,但没有从其中复制数据。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
流程
在主区域中,创建一个新的同步组,状态设置为 允许。
语法
radosgw-admin sync group create --group-id=GROUP_ID --status=allowed
Example
[ceph: root@host01 /]# radosgw-admin sync group create --group-id=group1 --status=allowed
注意在创建完全配置的 zonegroup 复制策略前,建议将--
status
设置为允许的
,以防止复制启动。创建流。
语法
radosgw-admin sync group flow create --group-id=GROUP_ID --flow-id=FLOW_ID --flow-type=directional --source-zone=SOURCE_ZONE_NAME --dest-zone=DESTINATION_ZONE_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync group flow create --group-id=group1 --flow-id=us-west-backup --flow-type=directional --source-zone=us-west --dest-zone=us-west-2
创建管道。
语法
radosgw-admin sync group pipe create --group-id=GROUP_ID --pipe-id=PIPE_ID --source-zones='SOURCE_ZONE_NAME' --dest-zones='DESTINATION_ZONE_NAME'
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --group-id=group1 --pipe-id=pipe1 --source-zones='us-west' --dest-zones='us-west-2'
更新并提交新周期。
Example
[ceph: root@host01 /]# radosgw-admin period update --commit
注意对于 zonegroup 策略,需要更新并提交周期。
在两个站点中使用 sync info 验证 zonegroup 的源和目标。
语法
radosgw-admin sync info
5.9.3. 为存储桶设置方向策略
使用同步策略引擎,设置存储桶的策略。
在以下示例中,创建组策略并配置数据流,以将数据从一个区域移动到另一个区域。另外,为 zonegroups 配置管道,以定义可以使用此数据流的存储桶。以下示例中的系统包括 3 个区域: us-east
(主区域)、us-west
(secondary zone)和 us-west-2
(backup zone)。在这里,us-west-2
是 us-west
的副本,但没有从其中复制数据。
为 zonegroups 和 bucket 设置方向策略之间的区别是您需要指定 the- bucket
选项。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
流程
在主区域中,创建一个新的同步组,状态设置为 允许。
语法
radosgw-admin sync group create --group-id=GROUP_ID --status=allowed --bucket=BUCKET_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync group create --group-id=group1 --status=allowed --bucket=buck
注意在创建完全配置的 zonegroup 复制策略前,建议将--
status
设置为允许的
,以防止复制启动。创建流。
语法
radosgw-admin sync group flow create --bucket-name=BUCKET_NAME --group-id=GROUP_ID --flow-id=FLOW_ID --flow-type=directional --source-zone=SOURCE_ZONE_NAME --dest-zone=DESTINATION_ZONE_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync group flow create --bucket-name=buck --group-id=group1 --flow-id=us-west-backup --flow-type=directional --source-zone=us-west --dest-zone=us-west-2
创建管道。
语法
radosgw-admin sync group pipe create --group-id=GROUP_ID --bucket-name=BUCKET_NAME --pipe-id=PIPE_ID --source-zones='SOURCE_ZONE_NAME' --dest-zones='DESTINATION_ZONE_NAME'
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --group-id=group1 --bucket-name=buck --pipe-id=pipe1 --source-zones='us-west' --dest-zones='us-west-2'
在两个站点中使用 sync info 验证 zonegroup 的源和目标。
语法
radosgw-admin sync info --bucket-name=BUCKET_NAME
5.9.4. 为存储桶设置双向策略
bucket 级别策略的数据流继承自 zonegroup 策略。bucket 级别策略不需要更改数据流和管道,因为 bucket 级别策略流和管道仅是 zonegroup 策略中定义的流的子集。
- 存储 同级别策略可以启用还没有启用的管道,但在 zonegroup 策略中被禁止的除外。
- bucket 级别策略不需要周期更新。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
- 已创建一个同步流。
流程
将 zonegroup policy
--status
设置为允许
允许每个存储桶复制。Example
[ceph: root@host01 /]# radosgw-admin sync group modify --group-id=group1 --status=allowed
修改 zonegroup 策略后更新周期。
Example
[ceph: root@host01 /]# radosgw-admin period update --commit
为要同步到的存储桶创建一个同步组,并将 set-
status
设置为启用
。Example
[ceph: root@host01 /]# radosgw-admin sync group create --bucket=buck \ --group-id=buck-default --status=enabled
为上一步中创建的组创建一个管道。流从数据流为 symmetrical 的 zonegroup 级别策略继承。
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --bucket=buck \ --group-id=buck-default --pipe-id=pipe1 \ --source-zones='*' --dest-zones='*'
注意使用通配符 * 指定存储桶复制的源和目标区域。
可选: 要检索有关同步策略定义的预期存储桶同步源和目标的信息,请使用--bucket 标志运行
radosgw-admin bucket sync info
命令。Example
[ceph: root@host01 /]# radosgw-admin bucket sync info --bucket buck realm 33157555-f387-44fc-b4b4-3f9c0b32cd66 (india) zonegroup 594f1f63-de6f-4e1e-90b6-105114d7ad55 (shared) zone ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5 (primary) bucket :buck[ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1] source zone e0e75beb-4e28-45ff-8d48-9710de06dcd0 bucket :buck[ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1]
可选: 要检索有关同步策略定义的预期同步源和目标的信息,请使用- bucket 标志运行
radosgw-admin sync info
命令。Example
[ceph: root@host01 /]# radosgw-admin sync info --bucket buck { "id": "pipe1", "source": { "zone": "secondary", "bucket": "buck:ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1" }, "dest": { "zone": "primary", "bucket": "buck:ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1" }, "params": { "source": { "filter": { "tags": [] } }, "dest": {}, "priority": 0, "mode": "system", "user": "" } }, { "id": "pipe1", "source": { "zone": "primary", "bucket": "buck:ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1" }, "dest": { "zone": "secondary", "bucket": "buck:ffaa5ba4-c1bd-4c17-b176-2fe34004b4c5.16191.1" }, "params": { "source": { "filter": { "tags": [] } }, "dest": {}, "priority": 0, "mode": "system", "user": "" } }
5.9.5. 在存储桶间同步
您可以在区域间同步源和目标存储桶之间的数据,但不能在同一区内同步。请注意,内部数据仍是从目标区的源中拉取的。
通配符存储桶名称表示当前存储桶位于存储桶同步策略的上下文中。
bucket 之间有两种同步:
- 从存储桶同步 - 您需要指定源存储桶。
- 同步到存储桶 - 您需要指定目标存储桶。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
与不同存储桶同步
创建一个同步组从另一个区的存储桶中拉取数据。
语法
radosgw-admin sync group create --bucket=BUCKET_NAME --group-id=GROUP_ID --status=enabled
Example
[ceph: root@host01 /]# radosgw-admin sync group create --bucket=buck4 --group-id=buck4-default --status=enabled
拉取数据。
语法
radosgw-admin sync group pipe create --bucket-name=BUCKET_NAME --group-id=GROUP_ID --pipe-id=PIPE_ID --source-zones=SOURCE_ZONE_NAME --source-bucket=SOURCE_BUCKET_NAME --dest-zones=DESTINATION_ZONE_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --bucket=buck4 \ --group-id=buck4-default --pipe-id=pipe1 \ --source-zones='*' --source-bucket=buck5 \ --dest-zones='*'
在本例中,您可以看到源存储桶为
buck5
。可选:从特定区中的存储桶同步。
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe modify --bucket=buck4 \ --group-id=buck4-default --pipe-id=pipe1 \ --source-zones=us-west --source-bucket=buck5 \ --dest-zones='*'
检查同步状态。
语法
radosgw-admin sync info --bucket-name=BUCKET_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync info --bucket=buck4 { "sources": [], "dests": [], "hints": { "sources": [], "dests": [ "buck4:115b12b3-....14433.2" ] }, "resolved-hints-1": { "sources": [], "dests": [ { "id": "pipe1", "source": { "zone": "us-west", "bucket": "buck5" }, "dest": { "zone": "us-east", "bucket": "buck4:115b12b3-....14433.2" }, ... }, { "id": "pipe1", "source": { "zone": "us-west", "bucket": "buck5" }, "dest": { "zone": "us-west-2", "bucket": "buck4:115b12b3-....14433.2" }, ... } ] }, "resolved-hints": { "sources": [], "dests": [] }
请注意,有
解析的提示
,这意味着存储桶buck5
发现有关从它间接进行buck4
同步的存储桶,而不是从自己的策略中进行同步。buck5
本身的策略为空。
同步到不同的存储桶
创建同步组。
语法
radosgw-admin sync group create --bucket=BUCKET_NAME --group-id=GROUP_ID --status=enabled
Example
[ceph: root@host01 /]# radosgw-admin sync group create --bucket=buck6 \ --group-id=buck6-default --status=enabled
推送数据。
语法
radosgw-admin sync group pipe create --bucket-name=BUCKET_NAME --group-id=GROUP_ID --pipe-id=PIPE_ID --source-zones=SOURCE_ZONE_NAME --dest-zones=DESTINATION_ZONE_NAME --dest-bucket=DESTINATION_BUCKET_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --bucket=buck6 \ --group-id=buck6-default --pipe-id=pipe1 \ --source-zones='*' --dest-zones='*' --dest-bucket=buck5
在本例中,您可以看到目标存储桶为
buck5
。可选:同步到特定区域中的存储桶。
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe modify --bucket=buck6 \ --group-id=buck6-default --pipe-id=pipe1 \ --source-zones='*' --dest-zones='us-west' --dest-bucket=buck5
检查同步状态。
语法
radosgw-admin sync info --bucket-name=BUCKET_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync info --bucket buck5 { "sources": [], "dests": [ { "id": "pipe1", "source": { "zone": "us-west", "bucket": "buck6:c7887c5b-f6ff-4d5f-9736-aa5cdb4a15e8.20493.4" }, "dest": { "zone": "us-east", "bucket": "buck5" }, "params": { "source": { "filter": { "tags": [] } }, "dest": {}, "priority": 0, "mode": "system", "user": "s3cmd" } }, ], "hints": { "sources": [], "dests": [ "buck5" ] }, "resolved-hints-1": { "sources": [], "dests": [] }, "resolved-hints": { "sources": [], "dests": [] } }
5.9.6. 过滤对象
使用前缀和标签过滤存储桶中的对象。您还可以在 zonegroup 级别策略上设置对象过滤器。如果使用了 --bucket
选项,则在存储桶级别上设置存储桶。
在以下示例中,从一个区域的 buck1
存储桶同步与另一个区中的 buck1
存储桶与以前缀 foo/
开头的对象同步。同样,您可以过滤带有标签的对象,如 color=blue
。前缀和标签可以合并,在其中对象需要同时同步。也可以传递 priority 参数,它可用于确定是否有多个不同的规则匹配。此配置决定了要使用的规则。
- 如果同步策略中的标签有多个标签,当同步对象时,它会同步与至少一个标签匹配的对象,即键值对。对象可能与所有标签集不匹配。
- 如果设置了 prefix 和 tag,则对象必须具有前缀,并且任何一个标签都应匹配。只有这样,它会相互同步。
先决条件
- 至少两个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
- 创建存储桶。
流程
创建新的同步组。如果要在存储桶级别创建,请使用 the-
bucket
选项。语法
radosgw-admin sync group create --bucket=BUCKET_NAME --group-id=GROUP_ID --status=enabled
Example
[ceph: root@host01 /]# radosgw-admin sync group create --bucket=buck1 --group-id=buck8-default --status=enabled
对象与标签匹配的存储桶之间的同步。流从数据流为 symmetrical 的 zonegroup 级别策略继承。
语法
radosgw-admin sync group pipe create --bucket=BUCKET_NAME --group-id=GROUP_ID --pipe-id=PIPE_ID --tags-add=KEY1=VALUE1,KEY2=VALUE2 --source-zones='ZONE_NAME1','ZONE_NAME2' --dest-zones='ZONE_NAME1','ZONE_NAME2'
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --bucket=buck1 \ --group-id=buck1-default --pipe-id=pipe-tags \ --tags-add=color=blue,color=red --source-zones='*' \ --dest-zones='*'
对象与前缀匹配的存储桶之间的同步。流从数据流为 symmetrical 的 zonegroup 级别策略继承。
语法
radosgw-admin sync group pipe create --bucket=BUCKET_NAME --group-id=GROUP_ID --pipe-id=PIPE_ID --prefix=PREFIX --source-zones='ZONE_NAME1','ZONE_NAME2' --dest-zones='ZONE_NAME1','ZONE_NAME2'
Example
[ceph: root@host01 /]# radosgw-admin sync group pipe create --bucket=buck1 \ --group-id=buck1-default --pipe-id=pipe-prefix \ --prefix=foo/ --source-zones='*' --dest-zones='*' \
检查更新的同步。
语法
radosgw-admin sync info --bucket=BUCKET_NAME
Example
[ceph: root@host01 /]# radosgw-admin sync info --bucket=buck1
注意在示例中,只有两个不同的目的地和没有源,各自用于配置。当同步进程发生时,它会为其同步的每个对象选择相关规则。
5.9.7. 在存储桶间禁用策略
您可以禁用存储桶之间的策略,以及与 禁止
或允许
的状态同步信息。
如需可用于 zonegroup 和 bucket 级别同步策略的不同组合,请参阅多站点同步策略 组状态。
在某些情况下,若要在两个存储桶之间中断复制,您可以将存储桶的组策略设置为 禁止
。如果任何存储桶的同步没有发生,您也可以在 zonegroup 级别禁用策略。
您还可以使用 radosgw-admin sync group create
命令,以 disabled 状态或禁止状态创建同步策略。
先决条件
- 一个正在运行的 Red Hat Ceph Storage 集群。
- 已安装 Ceph 对象网关。
流程
运行
sync group modify
命令,将允许 的状态更改为 禁止。Example
[ceph: root@host01 /]# radosgw-admin sync group modify --group-id buck-default --status forbidden --bucket buck { "groups": [ { "id": "buck-default", "data_flow": {}, "pipes": [ { "id": "pipe1", "source": { "bucket": "*", "zones": [ "*" ] }, "dest": { "bucket": "*", "zones": [ "*" ] }, "params": { "source": { "filter": { "tags": [] } }, "dest": {}, "priority": 0, "mode": "system", } } ], "status": "forbidden" } ] }
在本例中,bucket
buck
的复制会在区域us-east
和us-west
之间中断。注意不需要对周期的更新和提交,因为这是存储桶同步策略。
可选:运行
sync info 命令来检查
存储桶的同步状态
。Example
[ceph: root@host01 /]# radosgw-admin sync info --bucket buck { "sources": [], "dests": [], "hints": { "sources": [], "dests": [] }, "resolved-hints-1": { "sources": [], "dests": [] }, "resolved-hints": { "sources": [], "dests": [] } }
注意复制中断时,没有源和目标目标。