当前位置: 首页 > news >正文

如何使用rclone将腾讯云COS桶中的数据同步到华为云OBS

在多云策略与数据迁移趋势下,企业往往需要将数据在不同云服务提供商之间进行迁移。本文介绍如何使用rclone工具同步腾讯云COS(Cloud Object Storage)桶中的数据到华为云OBS(Object Storage Service)。先决条件是您已经使用华为云在线迁移工具完成了初始数据迁移,现在我们需要保持后续的数据一致性。
image.png
迁移过程如下:
输入源端桶与目的桶的各个配置信息,点击下一步:
image.png
这里直接默认,点击下一步:
image.png
到这里数据就可以开始同步了!
但是这里要注意账号密钥的权限:
image.png
我创建了一个用户组obs-list,将obs的用户加入,并赋予了OBS Buckets Viewer OBS ReadOnlyAccess权限(应该赋予OBS ReadOnlyAccess就可以)
image.png
存储桶,桶策略绑定了下面的权限:
image.png
image.png
其实华为云也有同步任务这个选项可以增量同步,但是看了一眼:
创建一个同步任务
image.png
image.png
image.png
image.png
but我源站新建了一个文件没有能在这里看到更新
image.png
访问:同步请求接收地址放弃了…
image.png
尝试一下rclone吧还是!

什么是rclone?

rclone是一款开源的命令行工具,支持同步文件和目录到多种云存储服务提供商。rclone具有多种特性,包括但不限于复制、同步、迁移、加密等。它支持多种云存储服务,例如Amazon S3, Microsoft OneDrive, Google Drive, Alibaba Cloud OSS, Huawei Cloud OBS以及腾讯云COS等。

开始使用

步骤1:安装rclone

访问rclone官方网站(https://rclone.org/downloads/),下载适合您操作系统的rclone版本并安装。例如,对于Linux系统可以使用以下命令:

curl -O https://downloads.rclone.org/rclone-current-linux-amd64.zip
unzip rclone-current-linux-amd64.zip
cd rclone-*-linux-amd64
sudo cp rclone /usr/bin/
sudo chown root:root /usr/bin/rclone
sudo chmod 755 /usr/bin/rclone

步骤2:配置rclone

使用rclone配置命令交互式创建新配置。

rclone config
添加华为云OBS
  1. 选择“n”新建远程配置。

image.png

  1. 输入配置名称,如 HuaweiOBS

image.png

  1. 选择存储类型,输入 s3,选择 13

image.png

  1. 输入华为云OBS的相关信息,包括区域access_key_idsecret_access_key等。

image.png

  1. 访问限制,直接回车,不需要。是否配置高级设置,输入n否.是否保存,输入y保存!

image.png

添加腾讯云COS
  1. 同样使用“n”创建新的远程配置。

image.png

  1. 输入配置名称,如 TencentCOS

image.png

  1. 选择存储类型,选择 s3,选择 13(腾讯云)。

image.png

  1. 输入腾讯云TencentCOS的相关信息,包括区域access_key_idsecret_access_key等。

image.png

  1. 输入腾讯云COS的相关信息。访问限制,直接回车,不需要。是否配置高级设置,输入n否.是否保存,输入y保存!

image.png

步骤3:运行rclone同步命令

使用以下rclone命令将腾讯云COS的数据同步到华为云OBS。请将 TencentCOS:bucket-nameHuaweiOBS:bucket-name 替换为您自己的具体存储桶名称。

rclone sync TencentCOS:bucket-name HuaweiOBS:bucket-name --progress
###or
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name 

--progress 参数可以让您实时看到同步的进度。
image.png

步骤4:设置定时任务(可选)

要保持数据持续同步,可以在服务器上设置定时任务。以下是一个示例cron任务,它每天凌晨1点执行数据同步。

打开cron编辑器:

crontab -e

添加以下行(确保您已经替换命令中的存储桶名):

0 1 * * * rclone sync TencentCOS:bucket-name HuaweiOBS:bucket-name --log-file=/var/log/rclone.log

保存并退出编辑器。

其他注意的:

一些加快速度的参数:

image.png
发现了没有同时传输的数量为4!
可以这样修改一下:

  • **调整并发设置 **--transfers: 设置同时进行文件传输的数量,默认通常是4。例如,如果想一次同步16个文件,可以使用 --transfers 16 作为命令参数
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name --transfers 16

image.png
恩 发现同步完成后**checking **数量为8?

  • **--checkers**: 设置同时进行检查操作的数量。检查操作是指在上传文件前检查文件是否需要更新。默认值通常是8。增加这个值可以加快检查的速度,但可能会消耗更多的资源
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name  --transfers 16 --checkers 16 
  • 使用**--fast-list**选项: 使用此选项可以减少S3(或兼容S3)API所需的请求数量,特别是在包含大量文件的目录中。它通过使用更少的请求来获取更多的文件列表信息来实现。
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name  --fast-list
  • 使用**--size-only****--checksum** 如果你绕过了修改日期的检查,而只根据文件大小(--size-only)或根据校验和(--checksum)来判断文件是否需要被同步,这可能会减次检查时间。
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name  --size-only

或者

rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name  --checksum

rclone sync 与rclone copy

rclone syncrclone copy都可以对数据进行复制。不同处是copy是增量复制,只复制目的端缺少的。例如两端数据一样后,源端删除了某个文件a.txt,再执行一次copy,目的端对应的文件a.txt仍然存在;
sync是同步,会将目的端同步为源端的情况,会删除目的端中源端没有的文件。例如两端数据一样后,源端删除了某个文件a.txt,再执行一次sync,目的端对应的文件a.txt也会被删掉。
具体的可以验证一下!

生成配置文件的方式

参照上面配置了rclone config的工作节点:

ls /root/.config/rclone

image.png
cat rclone.conf:

[HuaweiOBS]
type = s3
provider = Other
env_auth = false
access_key_id = xxxxx
secret_access_key = xxxxxxxxxxxxxxxxxxxxx
region = cn-north-4
endpoint = obs.cn-north-4.myhuaweicloud.com

[TencentCOS]
type = s3
provider = Other
env_auth = false
access_key_id = xxxxxxxxxxxxxxxx
secret_access_key = xxxxxxxxxxxxxxx
region = ap-shanghai
endpoint = cos.ap-shanghai.myqcloud.com

image.png
步骤2也可以这样生成配置文件,然后继续3 4的操作!

结论

通过以上步骤,您可以轻松地使用rclone将腾讯云COS桶中的数据同步到华为云OBS。确保在执行过程中准确无误地替换了所有必须的配置信息,以保证同步的成功。若您需要进一步的自定义或了解高级功能,请访问rclone的官方文档。
注:以上大纲chatgpt生成,参数 and copy用法以及生成配置文件方式为个人尝试!

相关文章:

  • Docker实践笔记7:构建MySQL 8镜像
  • Linux下的C++ socket编程实例
  • 有关Vue、微信小程序、UniApp中的CSS中的宽度width单位、自适应
  • NSGA-II求解微电网多目标优化调度(MATLAB)
  • CMakeLists.txt:打印find_package变量;判断库文件路径设定是否正确;install文件设置
  • Redis-Redis缓存高可用集群
  • 自监督LIGHTLY SSL教程
  • 【前端学java】Java中的异常处理(15)完结
  • 【每日一题】2824. 统计和小于目标的下标对数目-2023.11.24
  • electron实现截图的功能
  • 什么是切片
  • HTML所有功能大汇总
  • 使用Pytorch从零开始构建RNN
  • (二)汇编语句组成
  • 【云原生 Prometheus篇】Prometheus架构详解与核心组件的应用实例(Exporters、Grafana...)
  • 读像火箭科学家一样思考笔记07_探月思维
  • Redis的性能,哨兵模式,集群,
  • 5个高防CDN的特点
  • Ubuntu安装CUDA驱动
  • HarmonyOS(五)—— 认识页面和自定义组件生命周期
  • 国务院关税税则委:调整对原产于美国的进口商品加征关税措施
  • 中国巴西民间推动建立经第三方验证的“森林友好型”牛肉供应链
  • 万科:存续债券均正常付息兑付
  • 1至4月我国汽车产销量首次双超千万辆
  • 10名“鬼火少年”凌晨结队在城区飙车,警方:涉非法改装,正处理
  • 巴基斯坦称未违反停火协议