前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何使用rclone将腾讯云COS桶中的数据同步到华为云OBS

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

原创
作者头像
对你无可奈何
修改2023-11-21 20:32:44
6380
修改2023-11-21 20:32:44
举报
文章被收录于专栏:运维专栏运维专栏

在多云策略与数据迁移趋势下,企业往往需要将数据在不同云服务提供商之间进行迁移。本文介绍如何使用rclone工具同步腾讯云COS(Cloud Object Storage)桶中的数据到华为云OBS(Object Storage Service)。先决条件是您已经使用华为云在线迁移工具完成了初始数据迁移,现在我们需要保持后续的数据一致性。

迁移过程如下:

输入源端桶与目的桶的各个配置信息,点击下一步:

这里直接默认,点击下一步:

到这里数据就可以开始同步了!

但是这里要注意账号密钥的权限:

我创建了一个用户组obs-list,将obs的用户加入,并赋予了OBS Buckets Viewer OBS ReadOnlyAccess权限(应该赋予OBS ReadOnlyAccess就可以)

存储桶,桶策略绑定了下面的权限:

其实华为云也有同步任务这个选项可以增量同步,但是看了一眼:

创建一个同步任务

but我源站新建了一个文件没有能在这里看到更新

尝试一下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系统可以使用以下命令:

代码语言:shell
复制
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配置命令交互式创建新配置。

代码语言:shell
复制
rclone config
添加华为云OBS
  1. 选择“n”新建远程配置。
  1. 输入配置名称,如 HuaweiOBS
  1. 选择存储类型,输入 s3,选择 13
  1. 输入华为云OBS的相关信息,包括区域access_key_idsecret_access_key等。
  1. 完成配置,保存并退出。
添加腾讯云COS
  1. 同样使用“n”创建新的远程配置。
  1. 输入配置名称,如 TencentCOS
  1. 选择存储类型,选择 s3,选择 13(腾讯云)。
  1. 输入腾讯云TencentCOS的相关信息,包括区域access_key_idsecret_access_key等。
  1. 输入腾讯云COS的相关信息。访问限制,直接回车,不需要。是否配置高级设置,输入n否.是否保存,输入y保存!

步骤3:运行rclone同步命令

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

代码语言:shell
复制
rclone sync TencentCOS:bucket-name HuaweiOBS:bucket-name --progress
###or
rclone sync -P TencentCOS:bucket-name HuaweiOBS:bucket-name 

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

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

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

打开cron编辑器:

代码语言:shell
复制
crontab -e

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

代码语言:txt
复制
0 1 * * * rclone sync TencentCOS:bucket-name HuaweiOBS:bucket-name --log-file=/var/log/rclone.log

保存并退出编辑器。

其他注意的:

一些加快速度的参数:

发现了没有同时传输的数量为4!

可以这样修改一下:

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

恩 发现同步完成后checking 数量为8?

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

或者

代码语言:shell
复制
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

cat rclone.conf:

代码语言:shell
复制
[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

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

结论

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

注:以上大纲chatgpt生成,参数 and copy用法以及生成配置文件方式为个人尝试!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是rclone?
  • 开始使用
    • 步骤1:安装rclone
      • 步骤2:配置rclone
        • 添加华为云OBS
        • 添加腾讯云COS
      • 步骤3:运行rclone同步命令
        • 步骤4:设置定时任务(可选)
        • 其他注意的:
          • 一些加快速度的参数:
          • rclone sync 与rclone copy
          • 结论
          相关产品与服务
          对象存储
          对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
          http://www.vxiaotou.com