本站提供 Linux 服务器运维,自动化脚本编写等服务,如有需要请联系博主微信:xiaozme

Rclone 是一个命令行程序, 支持 Windows、Linux、MacOS 等多种系统,可挂载多达 40 多种网络存储,一款不可多得的挂载神器,用这篇文章来聊一聊 Rclone 的一些说明和注意事项。

安装 Rclone

这篇文章以 CentOS 7 为例,下面命令均在 CentOS 7 执行。Rclone 使用 Golang 进行开发,官方已经编译好二进制包,安装非常简便,执行如下一条命令即可:

curl https://rclone.org/install.sh | sudo bash

如果是生产或者比较重要的环境,建议创建一个单独的用户来运行 Rclone,这篇文章不做详细介绍。安装完成后,执行命令rclone -V查看当前版本:

[root@bf-xiaoz ~]
rclone v1.53.3
- os/arch: linux/amd64
- go version: go1.15.5

机器配置

我们通常的做法,一般是在 VPS 小鸡上安装 Rclone 并挂载各种云存储(如 OneDrive),这篇文章不对配置存储做介绍(假设您已经添加好存储)。Rclone 通过网络挂载方式将云存储挂载到本地机器,既然是通过网络挂载,性能和稳定性自然比不上本地磁盘。

另外在使用过程中可能还会发现 Rclone 占用 CPU、内存过高等情况,这个和机器本身性能以及 Rclone 配置有一定关系,如果是个人使用,建议的及其配置为:

  • CPU:2 核
  • 内存:1Gb 以上
  • 磁盘:不低于 30Gb

挂载参数

Rclone 挂载依赖于fuse,因此需要先安装:

yum -y install fuse

这里我已经挂载了 OneDrive 存储,并将名称命名为od,可通过rclone listremotes命令查看到:

[rclone@bf-xiaoz rclone]$ rclone listremotes
od:

Rclone 配置文件位于$HOME/.config/rclone/rclone.conf,其中$HOME为用户家目录。

[rclone@bf-xiaoz ~]$ ls -l $HOME/.config/rclone/rclone.conf
-rw------- 1 rclone rclone 1876 Dec 27 18:32 /home/rclone/.config/rclone/rclone.conf

Rclone 缓存目录位于$HOME/.cache/rclone,如果您服务器挂载了额外的磁盘,建议将这个目录做软连接到非系统盘,避免 Rclone 使用中占用较多的系统磁盘。

下面我直接用自己的挂载命令来做说明:

rclone mount od:/file /data/wwwroot/xxx --allow-other --attr-timeout 5m --vfs-cache-mode full --vfs-cache-max-age 24h --vfs-cache-max-size 10G --vfs-read-chunk-size-limit 100M --buffer-size 100M --daemon

别被上面一串命令吓到,我们来拆分下,发现还是非常简单的:

  • rclone mount:是 rclone 挂载命令
  • od:/file:上面已经提到,xiaoz 提前配置好了 OneDrive,并将名称命名为odod:/file则是 OneDrive 上的路径
  • /data/wwwroot/xxx: 为本地文件夹路径(建议为空目录)
  • --allow-other:指的是允许非当前 Rclone 用户外的用户进行访问
  • --attr-timeout 5m:文件属性缓存,(大小,修改时间等)的时间。如果小鸡配置比较低,建议适当提高这个值,避免过多的和内核交互,占用资源。
  • -vfs-cache-mode full:开启 VFS 文件缓存,这样可减少 Rclone 与 API 交互,同时可提高文件读写效率
  • --vfs-cache-max-age 24h:VFS 文件缓存时间,这里设置的 24 小时,如果文件很少更改,建议设置更长的时间
  • --vfs-cache-max-size 10G:VFS 文件缓存上限大小,建议不超过当前空余磁盘的 50%
  • vfs-read-chunk-size-limit 100M:分块读取大小,这里设置的是 100M,可提高文件读的效率,比如 1G 的文件,大致分为 10 个块进行读取,但与此同时 API 请求次数也会增多
  • --buffer-size 100M:内存缓存,如果您内存比较小,可降低此值,如果内存比较大,可适当提高
  • --daemon:指后台方式运行

了解了上面参数含义后,便可根据小鸡的配置来适当调整,以免 Rclone 发生 CPU、内存莫名使用过多,而不知所措。更多参数说明,可参考官方文档:https://rclone.org/commands/rclone_mount/

取消挂载

通常情况,直接使用umount命令取消挂载即可:

umount /path/to/local/mount

或者使用fusermount

fusermount -u /path/to/local/mount

如果提示磁盘繁忙,只能暴力 kill 杀掉进程了,命令为:

pgrep 'rclone'|xargs kill -9

umount /path/to/local/mount

总结

  • 比较重要的环境,建议单独创建 rclone 用户来运行
  • Rclone 缓存目录建议设置为非系统分区(/
  • 如果机器配置较低,请降低文件缓存和内存缓存
  • 建议添加--allow-other参数,否则可能发生部分程序不可读(无权限)的情况

Rclone 可让小鸡秒变大盘鸡,但是也得合理配置参数,让其发挥出最佳性能,切记不要网上盲目复制粘贴参数,否则效果可能并不理想。

以上是 xiaoz 个人 Rclone 配置整理,并不代表最佳配置,仅供参考,如有不足或错误,还请留言指正。

Rclone 官网:https://rclone.org/