此文章与“如何使用rclone从AWS S3迁移到IBM COS - part 1”为连载,请先阅读part1,了解如何安装配置rclone工具。
这里是接着part1之后,再去配置腾讯云对象存储,实现多个存储桶之间的数据迁移和备份。
编辑rclone.conf文件,添加如下内容:
[tencent-cos]
type = s3 # s3后端存储类型
provider = Other
env_auth = false # 不从环境变量中获取密钥
access_key_id = AKIDXXXXXXXXXXXXXX # 腾讯云的secretId
secret_access_key = YYYYYYYYYYYYYYYYYYY # 腾讯云的secretKey
endpoint = cos.ap-guangzhou.myqcloud.com # COS的域名
至此,我们在Rclone中配置了IBM COS的连接,AWS S3的连接和腾讯云的对象存储的连接, 我们可以在安装有rclone的客户端执行几个对象存储之间的数据同步和传输。有关如何使用rclone,请查阅rclone的相关文档。
总结:
除了上述方式以外,IBM COS同时也支持很多s3兼容工具,类似cyberduck,tntdrive, cloudberry, s3browser,包括命令行工具aws s3cli等, 而且如果客户有浏览器的工作站,无需安装任何工具,自带的免费Aspera浏览器插件进行公网跨区域传输文件,相对三方工具传送质量和速度都很有保障
ICOS API
IBM COS提供非常完整的S3 API,常见开发语言比如java, python, node.js, GO 等都有对应的SDK工具包,开发人员可轻松上手
https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-sdk-about
访问IBM github站点安装COS python SDK,https://github.com/IBM/ibm-cos-sdk-python,下面是IBM在线文档提供的code样本,只用把其中的cos端点,api key以及服务的 CRN匹配已有环境的设定即可。
import ibm_boto3
from ibm_botocore.client import Config, ClientError
#Constants for IBM COS values
COS_ENDPOINT = “https://s3.private.us-south.cloud-object-storage.appdomain.cloud”
COS_API_KEY_ID = “xxx”
COS_INSTANCE_CRN = “xxx”
def upload_large_file(bucket_name, item_name, file_path):
print(“Starting large file upload for {0} to bucket: {1}”.format(item_name, bucket_name))
# set the chunk size to 5 MB
part_size = 1024 * 1024 * 5
# set threadhold to 5 MB
file_threshold = 1024 * 1024 * 5
# Create client connection
cos_cli = ibm_boto3.client("s3",
ibm_api_key_id=COS_API_KEY_ID,
ibm_service_instance_id=COS_INSTANCE_CRN,
config=Config(signature_version="oauth"),
endpoint_url=COS_ENDPOINT
)
# set the transfer threshold and chunk size in config settings
transfer_config = ibm_boto3.s3.transfer.TransferConfig(
multipart_threshold=file_threshold,
multipart_chunksize=part_size
)
# create transfer manager
transfer_mgr = ibm_boto3.s3.transfer.TransferManager(cos_cli, config=transfer_config)
try:
# initiate file upload
future = transfer_mgr.upload(file_path, bucket_name, item_name)
# wait for upload to complete
future.result()
print ("Large file upload complete!")
except Exception as e:
print("Unable to complete large file upload: {0}".format(e))
finally:
transfer_mgr.shutdown()
def main()
upload_large_file(‘iso-image-bucket’, ‘100G.file’, ‘/data/100G.file’ )
if name == “main”:
main()
执行上传,如果带宽过大,可以通过设置 part_size和file_threshold来调整传送速度
[root@centos-s3fs ~]# python upload_large_file.py
Starting large file upload for 100G.file to bucket: iso-image-bucket
Large file upload complete!
上传成功!!!