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 {
// エンドポイントを中国 (杭州) リージョンに設定します。他のリージョンについては、エンドポイントを適宜変更してください。
String endpoint = "https://oss-cn-hangzhou.aliyuncs.com";
// エンドポイントが配置されているリージョン (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);
// OSS がデータレプリケーションに使用することを承認する RAM ロールの名前を指定します。ロールには、ソースバケットで SRR を実行し、宛先バケットでレプリケートされたオブジェクトを受信する権限が付与されている必要があります。
request.setSyncRole("yourRole");
// SSE-KMS 暗号化で作成されたオブジェクトを OSS がレプリケートするかどうかを指定します。
//request.setSseKmsEncryptedObjectsStatus("Enabled");
// SSE-KMS キー 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);
// ソースバケットから宛先バケットへのオブジェクトの作成および更新操作をレプリケートします。
//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(
# データをレプリケートする宛先バケットを指定します。宛先バケットはソースバケットと同じアカウントに属している必要があります。
target_bucket_name='dest-bucket',
# 宛先バケットのリージョンを指定します。宛先バケットはソースバケットと同じリージョンにある必要があります。
target_bucket_location='oss-cn-hangzhou',
# OSS がデータレプリケーションに使用することを承認する 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 キー 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 キー ID を指定します。Status を Enabled に設定した場合、この要素は必須です。
keyId := "c4d49f85-ee30-426b-a5ed-95e9****"
// SSE-KMS 暗号化で作成されたオブジェクトを OSS がレプリケートするかどうかを指定します。
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",
// OSS がデータレプリケーションに使用することを承認する 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!")
}