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;
import com.aliyun.oss.ClientBuilderConfiguration;
import com.aliyun.oss.common.comm.SignVersion;
public class Demo {
public static void main(String[] args) throws Exception {
// エンドポイントを指定します。たとえば、バケットが中国 (杭州) リージョンにある場合、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。
String endpoint = "https://oss-cn-hangzhou.aliyuncs.com";
// エンドポイントに対応するリージョン ID を指定します(例:cn-hangzhou)。
String region = "cn-hangzhou";
// アクセス認証情報をコード内に保存しないことを強く推奨します。そうしないと、アクセス認証情報が漏洩し、アカウント内のすべてのリソースのセキュリティが脅かされる可能性があります。この例では、アクセス認証情報を環境変数から取得しています。サンプルコードを実行する前に、必要な環境変数を設定してください。
EnvironmentVariableCredentialsProvider credentialsProvider = CredentialsProviderFactory.newEnvironmentVariableCredentialsProvider();
// ソースバケットの名前を指定します。
String bucketName = "src-bucket";
// 送信先バケットを指定します。送信先バケットとソースバケットは、同一のアカウントに属している必要があります。
String targetBucketName = "dest-bucket";
// 送信先バケットが配置されているリージョンを指定します。送信先バケットとソースバケットは、同一のリージョンに配置されている必要があります。
String targetBucketLocation = "oss-cn-hangzhou";
// OSSClient インスタンスを作成します。
// OSSClient インスタンスが不要になった場合は、shutdown メソッドを呼び出してリソースを解放します。
ClientBuilderConfiguration clientBuilderConfiguration = new ClientBuilderConfiguration();
// V4 署名アルゴリズムを使用することを明示的に宣言します。
clientBuilderConfiguration.setSignatureVersion(SignVersion.V4);
OSS ossClient = OSSClientBuilder.create()
.endpoint(endpoint)
.credentialsProvider(credentialsProvider)
.clientConfiguration(clientBuilderConfiguration)
.region(region)
.build();
try {
AddBucketReplicationRequest request = new AddBucketReplicationRequest(bucketName);
request.setTargetBucketName(targetBucketName);
request.setTargetBucketLocation(targetBucketLocation);
// デフォルトでは既存データがレプリケーションされます。このパラメーターを false に設定すると、既存データのレプリケーションを無効化できます。
request.setEnableHistoricalObjectReplication(false);
// データレプリケーションを許可された RAM ロールの名前を指定します。このロールには、ソースバケットに対する SRR 実行および送信先バケットへの書き込み権限が必要です。
request.setSyncRole("yourRole");
// SSE-KMS を使用して暗号化されたオブジェクトをレプリケーションするかどうかを指定します。
//request.setSseKmsEncryptedObjectsStatus("Enabled");
// SSE-KMS で使用する CMK の ID を指定します。SseKmsEncryptedObjectsStatus を 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);
// ソースバケットから送信先バケットへ、オブジェクトの作成および更新操作をレプリケーションします。
//request.setReplicationActionList(actions);
ossClient.addBucketReplication(request);
} catch (OSSException oe) {
System.out.println("OSSException がキャッチされました。これは、リクエストが OSS に到達しましたが、何らかの理由でエラー応答で拒否されたことを意味します。");
System.out.println("エラーメッセージ:" + oe.getErrorMessage());
System.out.println("エラーコード:" + oe.getErrorCode());
System.out.println("リクエスト ID:" + oe.getRequestId());
System.out.println("ホスト ID:" + oe.getHostId());
} catch (ClientException ce) {
System.out.println("ClientException がキャッチされました。これは、クライアントが OSS との通信中にネットワークにアクセスできないなどの重大な内部問題に遭遇したことを意味します。");
System.out.println("エラーメッセージ:" + 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(
# 送信先バケットを指定します。送信先バケットとソースバケットは、同一のアカウントに属している必要があります。
target_bucket_name='dest-bucket',
# 送信先バケットが配置されているリージョンを指定します。送信先バケットとソースバケットは、同一のリージョンに配置されている必要があります。
target_bucket_location='oss-cn-hangzhou',
# データレプリケーションを許可された RAM ロールの名前を指定します。このロールには、ソースバケットに対する SRR 実行および送信先バケットへの書き込み権限が必要です。
sync_role_name='roleNameTest',
)
# レプリケーション対象のオブジェクトのプレフィックスを指定します。指定したプレフィックスを持つオブジェクトのみが送信先バケットへレプリケーションされます。
# prefix_list = ['prefix1', 'prefix2']
# データレプリケーションルールを設定します。
# replica_config = ReplicationRule(
# prefix_list=prefix_list,
# ソースバケットから送信先バケットへ、オブジェクトの作成および更新操作をレプリケーションします。
# 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 インスタンスを作成します。
// yourEndpoint をバケットのリージョンのエンドポイントに設定します(例:中国 (杭州) リージョンの場合、エンドポイントを 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 を指定します。ステータスが 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,
// ソースバケットから送信先バケットへ、オブジェクトの作成および更新操作をレプリケーションします。
Action: "PUT",
Destination: &oss.ReplicationRuleDestination{
Bucket: destBucketName,
// 送信先バケットのリージョンを指定します。ソースおよび送信先のバケットは同一リージョンに配置する必要があります。
Location: "oss-cn-hangzhou",
},
// デフォルトでは既存データがレプリケーションされます。このパラメーターを "disabled" に設定すると、既存データのレプリケーションを無効化できます。
HistoricalObjectReplication: "disabled",
// データレプリケーションを許可された 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!")
}