同じアカウント内での SRR は、OSS SDK for Java、OSS SDK for Python、OSS SDK for Go のみでサポートされています。
Java
import com.aliyun.oss.ClientException;
import com.aliyun.oss.OSS;
import com.aliyun.oss.common.auth.*;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.OSSException;
import com.aliyun.oss.model.AddBucketReplicationRequest;
public class Demo {
public static void main(String[] args) throws Exception {
// この例では、中国 (杭州) リージョンのエンドポイントが使用されています。実際のエンドポイントを指定してください。
String endpoint = "https://oss-cn-hangzhou.aliyuncs.com";
// アクセスクレデンシャルをプロジェクトコードに保存しないことをお勧めします。そうしないと、アクセスクレデンシャルが漏洩する可能性があります。その結果、アカウント内のすべてのリソースのセキュリティが侵害されます。この例では、アクセスクレデンシャルは環境変数から取得されます。サンプルコードを実行する前に、環境変数が設定されていることを確認してください。
EnvironmentVariableCredentialsProvider credentialsProvider = CredentialsProviderFactory.newEnvironmentVariableCredentialsProvider();
// ソースバケットの名前を指定します。
String bucketName = "src-bucket";
// コピー先バケットの名前を指定します。ソースバケットとコピー先バケットは、同じ Alibaba Cloud アカウントに属している必要があります。
String targetBucketName = "dest-bucket";
// コピー先バケットが配置されているリージョンを指定します。ソースバケットとコピー先バケットは、同じリージョンに配置されている必要があります。
String targetBucketLocation = "oss-cn-hangzhou";
// OSSClient インスタンスを作成します。
OSS ossClient = new OSSClientBuilder().build(endpoint, credentialsProvider);
try {
AddBucketReplicationRequest request = new AddBucketReplicationRequest(bucketName);
request.setTargetBucketName(targetBucketName);
request.setTargetBucketLocation(targetBucketLocation);
// 履歴データをレプリケートするかどうかを指定します。デフォルトでは、履歴データはレプリケートされます。この例では、このパラメーターは false に設定されており、履歴データはレプリケートされないことを示します。
request.setEnableHistoricalObjectReplication(false);
// OSS がデータのレプリケートに使用する RAM ロールの名前を指定します。 RAM ロールには、ソースバケットで SRR を実行し、コピー先バケットでレプリケートされたオブジェクトを受信するための権限が必要です。
request.setSyncRole("yourRole");
// SSE-KMS を使用して暗号化されたオブジェクトをレプリケートするかどうかを指定します。
//request.setSseKmsEncryptedObjectsStatus("Enabled");
// SSE-KMS で使用される CMK ID を指定します。Status が Enabled に設定されている場合は、このパラメーターを指定する必要があります。
//request.setReplicaKmsKeyID("3542abdd-5821-4fb5-a425-90adca***");
//List prefixes = new ArrayList();
//prefixes.add("image/");
//prefixes.add("video");
//prefixes.add("a");
//prefixes.add("A");
// レプリケートするオブジェクトの名前に含まれるプレフィックスを指定します。プレフィックスを指定すると、名前にプレフィックスのいずれかが含まれるオブジェクトのみがコピー先バケットにレプリケートされます。
//request.setObjectPrefixList(prefixes);
//List actions = new ArrayList();
//actions.add(AddBucketReplicationRequest.ReplicationAction.PUT);
// OSS がソースバケットからコピー先バケットにオブジェクトの作成および更新操作をレプリケートするように指定します。
//request.setReplicationActionList(actions);
ossClient.addBucketReplication(request);
} catch (OSSException oe) {
System.out.println("Caught an OSSException, which means your request made it to OSS, "
+ "but was rejected with an error response for some reason.");
System.out.println("Error Message:" + oe.getErrorMessage());
System.out.println("Error Code:" + oe.getErrorCode());
System.out.println("Request ID:" + oe.getRequestId());
System.out.println("Host ID:" + oe.getHostId());
} catch (ClientException ce) {
System.out.println("Caught an ClientException, which means the client encountered "
+ "a serious internal problem while trying to communicate with OSS, "
+ "such as not being able to access the network.");
System.out.println("Error Message:" + ce.getMessage());
} finally {
if (ossClient != null) {
ossClient.shutdown();
}
}
}
}
Python
# -*- coding: utf-8 -*-
import oss2
from oss2.credentials import EnvironmentVariableCredentialsProvider
from oss2.models import ReplicationRule
# 環境変数からアクセスクレデンシャルを取得します。サンプルコードを実行する前に、OSS_ACCESS_KEY_ID および OSS_ACCESS_KEY_SECRET 環境変数が設定されていることを確認してください。
auth = oss2.ProviderAuth(EnvironmentVariableCredentialsProvider())
# ソースバケットが配置されているリージョンのエンドポイントを指定します。たとえば、バケットが中国 (杭州) リージョンにある場合は、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。
# ソースバケットの名前を指定します。例: src-bucket。
bucket = oss2.Bucket(auth, 'https://oss-cn-hangzhou.aliyuncs.com', 'src-bucket')
replica_config = ReplicationRule(
# コピー先バケットの名前を指定します。ソースバケットとコピー先バケットは、同じ Alibaba Cloud アカウントに属している必要があります。
target_bucket_name='dest-bucket',
# コピー先バケットが配置されているリージョンを指定します。ソースバケットとコピー先バケットは、同じリージョンに配置されている必要があります。
target_bucket_location='oss-cn-hangzhou',
# OSS がデータのレプリケートに使用する RAM ロールの名前を指定します。 RAM ロールには、ソースバケットで SRR を実行し、コピー先バケットでレプリケートされたオブジェクトを受信するための権限が必要です。
sync_role_name='roleNameTest',
)
# レプリケートするオブジェクトの名前に含まれるプレフィックスを指定します。プレフィックスを指定すると、名前にプレフィックスのいずれかが含まれるオブジェクトのみがコピー先バケットにレプリケートされます。
# prefix_list = ['prefix1', 'prefix2']
# データレプリケーションルールを指定します。
# replica_config = ReplicationRule(
# prefix_list=prefix_list,
# OSS がソースバケットからコピー先バケットにオブジェクトの作成および更新操作をレプリケートするように指定します。
# action_list=[ReplicationRule.PUT],
# コピー先バケットの名前を指定します。
# target_bucket_name='dest-bucket',
# コピー先バケットが配置されているリージョンを指定します。
# target_bucket_location='yourTargetBucketLocation',
# 履歴データをレプリケートするかどうかを指定します。デフォルトでは、履歴データはレプリケートされます。この例では、このパラメーターは False に設定されており、履歴データはレプリケートされないことを示します。
# is_enable_historical_object_replication=False,
# SSE-KMS を使用して暗号化されたオブジェクトをレプリケートします。
# sse_kms_encrypted_objects_status=ReplicationRule.ENABLED
# SSE-KMS で使用される CMK ID を指定します。コピー先バケットにレプリケートされたオブジェクトを SSE-KMS を使用して暗号化する場合は、このパラメーターを指定する必要があります。
# replica_kms_keyid='9468da86-3509-4f8d-a61e-6eab1eac****',
#)
# データレプリケーションを有効にします。
bucket.put_bucket_replication(replica_config)
Go
package main
import (
"encoding/xml"
"fmt"
"github.com/aliyun/aliyun-oss-go-sdk/oss"
"os"
)
func HandleError(err error) {
fmt.Println("Error:", err)
os.Exit(-1)
}
// データレプリケーションを有効にします。
func main() {
// 環境変数からアクセスクレデンシャルを取得します。サンプルコードを実行する前に、OSS_ACCESS_KEY_ID および OSS_ACCESS_KEY_SECRET 環境変数が設定されていることを確認してください。
provider, err := oss.NewEnvironmentVariableCredentialsProvider()
if err != nil {
fmt.Println("Error:", err)
os.Exit(-1)
}
// OSSClient インスタンスを作成します。
// バケットが配置されているリージョンのエンドポイントを指定します。たとえば、バケットが中国 (杭州) リージョンにある場合は、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。実際のエンドポイントを指定してください。
client, err := oss.New("yourEndpoint", "", "", oss.SetCredentialsProvider(&provider))
if err != nil {
fmt.Println("Error:", err)
os.Exit(-1)
}
// ソースバケットの名前を指定します。
srcbucketName := "yourSrcBucket"
// コピー先バケットの名前を指定します。
destBucketName := "yourDestBucket"
// 名前にプレフィックス prefix_1 と prefix_2 のいずれかが含まれるオブジェクトがコピー先バケットにレプリケートされるように指定します。
// ソースバケットからコピー先バケットにすべてのオブジェクトをレプリケートするには、プレフィックスを設定しないでください。
prefix1 := "prefix_1"
prefix2 := "prefix_2"
// SSE-KMS で使用される CMK ID を指定します。Status が Enabled に設定されている場合は、このパラメーターを指定する必要があります。
keyId := "c4d49f85-ee30-426b-a5ed-95e9****"
// SSE-KMS を使用して暗号化されたオブジェクトをレプリケートするかどうかを指定します。
source := "Enabled"
prefixSet := oss.ReplicationRulePrefix{Prefix: []*string{&prefix1, &prefix2}}
reqReplication := oss.PutBucketReplication{
Rule: []oss.ReplicationRule{
{
PrefixSet: &prefixSet,
// OSS がソースバケットからコピー先バケットにオブジェクトの作成および更新操作をレプリケートするように指定します。
Action: "PUT",
Destination: &oss.ReplicationRuleDestination{
Bucket: destBucketName,
// コピー先バケットが配置されているリージョンを指定します。ソースバケットとコピー先バケットは、同じリージョンに配置されている必要があります。
Location: "oss-cn-hangzhou",
},
// 履歴データをレプリケートするかどうかを指定します。デフォルトでは、履歴データはレプリケートされます。この例では、このパラメーターは disabled に設定されており、履歴データはレプリケートされないことを示します。
HistoricalObjectReplication: "disabled",
// OSS がデータのレプリケートに使用する RAM ロールの名前を指定します。 RAM ロールには、ソースバケットで SRR を実行し、コピー先バケットでレプリケートされたオブジェクトを受信するための権限が必要です。
SyncRole: "yourRole",
EncryptionConfiguration: &keyId,
SourceSelectionCriteria: &source,
},
},
}
xmlBody, err := xml.Marshal(reqReplication)
if err != nil {
HandleError(err)
}
err = client.PutBucketReplication(srcbucketName, string(xmlBody))
if err != nil {
HandleError(err)
}
fmt.Println("Put Bucket Replication Success!")
}