2020-08-11 11:33:01 -07:00

4.5 KiB
Raw Blame History

存储桶复制指南 Slack Docker Pulls

Bucket replication is designed to replicate selected objects in a bucket to a destination bucket. 存储桶复制功能可以把存储桶中选中的对象复制到目标存储桶。

要想复制一个存储桶上的对象,到同一集群或者不同集群的目标站点上的目标存储桶中,首先要为源存储桶和目标存储桶启用版本控制功能。最后需要在源MinIO服务器上配置目标站点和目标存储桶。

强调

  • 和AWS S3不同MinIO的源存储桶和目标存储桶名字可以一样可处理各种情况例如SplunkVeeam站点到站点DR
  • 与AWS S3不同MinIO纯天然支持跨源桶和目标桶的对象锁定保留。
  • AWS S3 Bucket Replication Config实现更简单像IAM Role, AccessControlTranslation, Metrics and SourceSelectionCriteria这些功能在MinIO中不需要.

如何使用?

如下所示在源群集上创建复制目标:

mc admin bucket remote add myminio/srcbucket https://accessKey:secretKey@replica-endpoint:9000/destbucket --service replication --region us-east-1
Role ARN = 'arn:minio:replication:us-east-1:c5be6b16-769d-432a-9ef1-4567081f3566:destbucket'

请注意admin需要具有源集群上的s3:GetReplicationConfigurationAction权限。在目标上使用的凭据需要具有s3:ReplicateObject权限. 成功创建并授权后将生成复制目标ARN。下面的命令列出了所有当前授权的复制目标:

mc admin bucket remote ls myminio/srcbucket --service "replication"
Role ARN = 'arn:minio:replication:us-east-1:c5be6b16-769d-432a-9ef1-4567081f3566:destbucket'

现在可以使用带有复制配置JSON文件把复制配置添加到源存储桶。上面的角色ARN作为配置中的json元素传入。

{
  "Role" :"arn:minio:replication:us-east-1:c5be6b16-769d-432a-9ef1-4567081f3566:destbucket",
  "Rules": [
    {
      "Status": "Enabled",
      "Priority": 1,
      "DeleteMarkerReplication": { "Status": "Disabled" },
      "Filter" : {
        "And": {
            "Prefix": "Tax",
            "Tags": [
                {
                "Key": "Year",
                "Value": "2019"
                },
                {
                "Key": "Company",
                "Value": "AcmeCorp"
                }
            ]
        }
      },
      "Destination": {
        "Bucket": "arn:aws:s3:::destbucket",
        "StorageClass": "STANDARD"
      }
    }
  ]
}
mc replicate add myminio/srcbucket/Tax --priority 1 --arn "arn:minio:replication:us-east-1:c5be6b16-769d-432a-9ef1-4567081f3566:destbucket" --tags "Year=2019&Company=AcmeCorp" --storage-class "STANDARD"
Replication configuration applied successfully to myminio/srcbucket.

复制配置遵循AWS S3规范. 现在上传到源存储桶中符合复制条件的任何对象都将被MinIO服务器自动复制到远程目标存储桶中。通过禁用配置中的特定规则或者删除复制配置都可以随时禁用复制。

按照S3规范当从源存储桶中删除一个对象后副本不会被删除。

delete

当对象锁定与复制结合使用时,源桶和目标桶都需要启用对象锁定。同理,如果目标也支持加密,则服务器端将复制加密的对象。

复制状态可以在源和目标对象的元数据中看到。在源端,根据复制的结果是成功还是失败,X-Amz-Replication-Status会从PENDING变更为COMPLETE或者 FAILED状态。 在目标端,对象成功复制,X-Amz-Replication-Status会被设置为REPLICA状态。在定期的磁盘扫描周期中,任何复制失败都将自动重新尝试。

put

head

进一步探索