Rclone是一个命令行程序,用于管理云存储上的文件。他打包了各大供应商云存储的接口提供统一的访问界面。rclone支持40多种云存储产品,包括对象存储、企业和消费者文件存储、服务以及标准传输协议。Rclone符合unix POSIX规范,支持于常见的shell工具,比如rsync、cp、 mv、mount、ls、ncdu、tree、rm 和cat等交互,Rclone使用我们耳闻能熟的语法,支持shell管道,支持---dry-run保护,同时为了保护数据的可靠性,Rclone可保留时间戳和始终进行文件验证校验和。Rclone多种文件传输协议,支持SFTP,HTTP,WebDAV,FTP和DLNA。Rclone是一个成熟的开源软件,最初受rsync的启发并采用Golang编写。其文档和社区也都非常好,提供广泛和友好的使用用例。
这里我们使用Rclone主要用来操作对象存储,可以用来上传对象、拉取对象,并可实现对象存储间的迁移。
Rclone 是一个 Go 程序,以单个二进制文件的形式出现。
要在 Linux/macOS/BSD 系统上安装 rclone,请运行(确保能访问到rclone.org这个网址):
curl https://rclone.org/install.sh | sudo bash
对于 beta 安装,运行:
curl https://rclone.org/install.sh | sudo bash -s beta
此脚本首先检查安装的 rclone 的版本,如果不需要,将不会重新下载。
获取并解包
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
运行rclone config
设置基本参数,根据命令提示输入即可
rclone config
rclone 为rclone 维护一个docker 映像。这些镜像是由 docker hub 从 rclone 源基于最小的 Alpine linux 镜像自动构建的。
该:latest
标签将始终指向最新的稳定版本,也可以使用该:beta
标签从 master 获取最新版本,还可以使用版本标签,例如:1.49.1
,:1.49
或:1
。
$ docker pull rclone/rclone:latest
latest: Pulling from rclone/rclone
Digest: sha256:0e0ced72671989bb837fea8e88578b3fc48371aa45d209663683e24cfdaa0e11
...
$ docker run --rm rclone/rclone:latest version
rclone v1.49.1
- os/arch: linux/amd64
- go version: go1.12.9
启动 rclone Docker 容器时,需要考虑一些命令行选项:
您需要将主机 rclone 配置目录挂载/config/rclone
到 Docker 容器中。由于 rclone 在其配置文件中更新令牌,并且更新过程涉及文件重命名,因此您需要挂载整个主机 rclone 配置目录,而不仅仅是单个主机 rclone 配置文件。
您需要将主机数据目录挂载/data
到 Docker 容器中。
默认情况下,Docker 容器内的 rclone 二进制文件以 UID=0(root)运行。因此,在运行中创建的所有文件的 UID=0。如果您的配置和数据文件驻留在具有非 root UID:GID 的主机上,您需要在容器启动命令行上传递这些文件。
如果要访问 RC 接口(通过 API 或 Web UI),则需要将 设置--rc-addr
为:5572
以便从容器外部连接到它。
确保您至少安装了Go 1.15。
git clone https://github.com/rclone/rclone.git
cd rclone
go build
# If on macOS and mount is wanted, instead run: make GOTAGS=cmount
./rclone version
首先,需要配置 rclone,由于对象存储系统具有相当复杂的身份验证,因此它们保存在配置文件中,可以通过以下命令进行配置:
rclone config
基本按照命令提示输入信息即可
通常语法是这样的
Syntax: [options] subcommand <parameters> <parameters...>
具体使用大家可以看每个命令的链接,这里以rclone copy为例,比如拉取一个对象存储文件:
rclone copy remote:test.jpg /tmp/download
其中remote指的就是在config阶段配置的一个远程对象存储连接,这个命令将会把图片拉取到本地目录,这里注意的是本地必须指向一个目录。
Rclone 有许多选项来控制其行为。
带参数的选项可以通过两种方式传递值, --option=value
或者--option value
。然而,布尔(真/假)选项的行为与其他选项略有不同,将选项 --boolean
设置为true
并且没有标志将其设置为false
。也可以指定--boolean=false
或 --boolean=true
。请注意,这--boolean false
是无效的 - 这被解析为--boolean
并且false
被解析为 rclone 的额外命令行参数。大家可以打开这个地址来查看所有的选项参数设置。
比如在命令后跟以下参数:
--bwlimit 10M
意味着将上传和下载带宽限制为 10 MiB/s。 注意这是每秒字节数而不是每秒位数。要使用单个限制,请以 KiB/s 为单位指定所需的带宽,或使用后缀 B|K|M|G|T|P。默认是0
不限制带宽。上传和下载带宽可以单独指定,如 --bwlimit UP:DOWN
,所以
--bwlimit 10M:100k
这意味着将上传带宽限制为 10 MiB/s,将下载带宽限制为 100 KiB/s。任何一个限制都可以“关闭”意味着没有限制,所以只限制您将使用的上传带宽
--bwlimit 10M:off
这会将上传带宽限制为 10 MiB/s,但下载带宽将不受限制。
其他相关追加参数设置大家可以自行查看。
Rclone 可以提供基于 Web 的 GUI(图形用户界面),不过目前官方说明目前属于实验阶段,不过目前使用也没有出现什么大问题。基于上面讲的命令,在终端中运行此命令,rclone 将下载并在 Web 浏览器中显示 GUI:
rclone rcd --rc-web-gui
如果您想检查更新,则可以添加--rc-web-gui-update
到命令行。
如果你发现你的 GUI 坏了,你可以通过 add 强制它更新--rc-web-gui-force-update
。
默认情况下,rclone 将打开您的浏览器。添加--rc-web-gui-no-open-browser
以禁用此功能。
如果 rclone 使用该--rc
标志运行,那么它会启动一个 HTTP 服务器,该服务器可用于使用其 API 远程控制 rclone。
具体使用大家可以查看Remote Control / API页面,里面有具体的说明,可以设置认证信息等,结合web界面展示加上远程调用,可以很方便的实现一些对象存储迁移等高级功能,并且方便的查看执行情况,启动http监听后,通常可以使用的rc命令,都可以通过http的方式进行调用,大家可以自行尝试。
以上就是分享的关于rclone的一些基本用法以及高级使用,欢迎大家共同探讨!
程序之路漫漫,吾将上下而求索