Rclone使用教程:参数的详解和相关配置

引言

已是黄昏独自愁,更着风和雨。 ——勿埋我心

  比如在copy文件的时候,单纯使用默认配置是不容易将性能发挥最大化的,这个时候就需要进行一些参数的调整了。

  在网上发现了一篇总结挺不错的文章,遂进行了转载,并在此基础上进行了格式的调整,方便我个人的阅读习惯。

设置

命令说明
rclone config添加、删除、管理网盘等操作
rclone config file显示配置文件的路径
rclone config show显示配置文件信息
root@qiantigers:~# rclone config
Current remotes:

Name                 Type
====                 ====
DB                 dropbox
GD                 drive

e) Edit existing remote
n) New remote
d) Delete remote
r) Rename remote
c) Copy remote
s) Set configuration password
q) Quit config
e/n/d/r/c/s/q>

语法

# 本地到网盘
rclone [功能选项] <本地路径> <配置名称:路径> [参数] [参数]

# 网盘到本地
rclone [功能选项] <配置名称:路径> <本地路径> [参数] [参数]

# 网盘到网盘
rclone [功能选项] <配置名称:路径> <配置名称:路径> [参数] [参数]

# [参数]为可选项

示例

# 复制到网盘,并显示实时传输进度,设置并行上传数为8

rclone copy -P /home/SunPma GD:/home/SunPma --transfers=8

# 如果需要服务端对服务端的传输可加以下参数(不消耗本地流量)

rclone copy 配置名称:网盘路径 配置名称:网盘路径 --drive-server-side-across-configs

功能

命令说明
rclone copy复制
rclone move移动,如果要在移动后删除空源目录,加上 --delete-empty-src-dirs 参数
rclone sync同步:将源目录同步到目标目录,只更改目标目录
rclone size查看网盘文件占用大小
rclone delete删除路径下的文件内容
rclone purge删除路径及其所有文件内容
rclone mkdir创建目录
rclone rmdir删除目录
rclone rmdirs删除指定环境下的空目录。如果加上 --leave-root 参数,则不会删除根目录
rclone check检查源和目的地址数据是否匹配
rclone ls列出指定路径下的所有的文件以及文件大小和路径
rclone lsl比上面多一个显示上传时间
rclone lsd列出指定路径下的目录
rclone lsf列出指定路径下的目录和文件

参数

命令说明
-n = --dry-run测试运行,查看Rclon在实际运行中会进行哪些操作
-P = --progress显示实时传输进度,500mS刷新一次,否则默认1分钟刷新一次
--cache-chunk-size 5M块的大小,默认5M越大上传越快,占用内存越多,太大可能会导致进程中断
--onedrive-chunk-size 100M提高OneDrive上传速度适用于G口宽带服务器(默认为320KB)
--drive-chunk-size 64M提高Google Drive上传速度适用于G口宽带服务器(默认为8M)
--cache-chunk-total-size SizeSuffix块可以在本地磁盘上占用的总大小,默认10G
--transfers=N并行文件数,默认为4
--config string指定配置文件路径,string为配置文件路径
--ignore-errors跳过错误
--size-only根据文件大小校验,不校验hash
--drive-server-side-across-configs服务端对服务端传输

日志

有4个级别的日志记录:ERROR NOTICE INFO DEBUG
默认情况下Rclon将生成ERROR NOTICE日志

命令说明
-qrclone将仅生成ERROR消息
-vrclone将生成ERROR NOTICE INFO 消息
-vvrclone 将生成ERROR NOTICE INFO DEBUG 消息
--log-level LEVEL标志控制日志级别

输出日志到文件

使用--log-file=FILE选项rclone会将Error Info Debug消息以及标准错误重定向到FILE

这里的FILE是你指定的日志文件路径

过滤

命令说明
--exclude排除文件或目录
--include包含文件或目录
--filter文件过滤规则,相当于上面两个选项的其它使用方式。包含规则以+开头,排除规则以-开头

文件类型过滤

例如:--exclude "*.bak" --filter "- *.bak"排除所有bak文件

例如:--include "*.{png,jpg}" --filter "+ *.{png,jpg}"包含所有pngjpg文件,排除其他文件

例如:--delete-excluded删除排除的文件。需配合过滤参数使用,否则无效

目录过滤

目录过滤需要在目录名称后面加上/否则会被当做文件进行匹配

/开头只会匹配根目录(指定目录下),否则匹配所目录,这同样适用于文件

  • --exclude ".git/"排除所有目录下的.git目录
  • --exclude "/.git/"只排除根目录下的.git目录
  • --exclude "{Video,Software}/"排除所有目录下的VideoSoftware目录
  • --exclude "/{Video,Software}/"只排除根目录下的VideoSoftware目录
  • --include "/{Video,Software}/**"仅包含根目录下的VideoSoftware目录的所有内容

大小过滤

默认大小单位为kBytes但可以使用k MG后缀

  • --min-size过滤小于指定大小的文件。比如--min-size 50表示不会传输小于50k的文件。
  • --max-size过滤大于指定大小的文件。比如--max-size 1G表示不会传输大于1G的文件。

实际使用中发现大小过滤两个选项不能同时使用

过滤规则文件

--filter-from <规则文件>从文件添加包含/排除规则

比如--filter-from filter-file.txt

过滤规则文件示例:

- secret*.jpg
+ *.jpg
+ *.png
+ file2.avi
- /dir/Trash/**
+ /dir/**
- *

环境变量

rclone中的每个选项都可以通过环境变量设置。环境变量的名称可以通过长选项名称进行转换,删除--前缀,更改-_大写并添加前缀RCLONE_环境变量的优先级会低于命令行选项,即通过命令行追加相应的选项时会覆盖环境变量设定的值。

比如设置最小上传大小--min-size 50使用环境变量是RCLONE_MIN_SIZE=50当环境变量设置后,在命令行中使用--min-size 100那么此时环境变量的值就会被覆盖

常用环境变量

命令说明
RCLONE_CONFIG自定义配置文件路径
RCLONE_CONFIG_PASS若 rclone 进行了加密设置,把此环境变量设置为密码,可自动解密配置文件
RCLONE_RETRIES上传失败重试次数,默认 3 次
RCLONE_RETRIES_SLEEP上传失败重试等待时间,默认禁用,单位s、m、h分别代表秒、分钟、小时
CLONE_TRANSFERS并行上传文件数
RCLONE_CACHE_CHUNK_SIZE块的大小,默认5M
RCLONE_CACHE_CHUNK_TOTAL_SIZE块可以在本地磁盘上占用的总大小,默认10G
RCLONE_IGNORE_ERRORS=true跳过错误

结语

  欢迎有疑惑在勿埋我心评论区留言,共同探讨相关问题。

参考资料:Rclone 使用教程 - 常用命令参数 - SunPma'Blog

无标签
打赏
评论区
头像
文章目录