rclone-cli

star 1

Rclone command-line cloud storage manager reference and usage guide. Use this skill whenever the user mentions rclone, or any task involving terminal-based cloud file operations such as upload, download, sync, copy, move, mount, or remote management. Triggers on S3-compatible storage, cloud-to-cloud transfer, remote mounts, backups, filtering, bandwidth control, encrypted remotes, bisync, and workflows across providers such as S3, OSS, COS, OBS, MinIO, Google Drive, Dropbox, OneDrive, and Azure Blob. Use even if the user does not explicitly say "rclone" when the work is clearly command-line cloud storage management.

chaunsin By chaunsin schedule Updated 4/22/2026

name: rclone-cli description: > Rclone command-line cloud storage manager reference and usage guide. Use this skill whenever the user mentions rclone, or any task involving terminal-based cloud file operations such as upload, download, sync, copy, move, mount, or remote management. Triggers on S3-compatible storage, cloud-to-cloud transfer, remote mounts, backups, filtering, bandwidth control, encrypted remotes, bisync, and workflows across providers such as S3, OSS, COS, OBS, MinIO, Google Drive, Dropbox, OneDrive, and Azure Blob. Use even if the user does not explicitly say "rclone" when the work is clearly command-line cloud storage management. metadata: author: chaunsin version: "0.1"

rclone — The Swiss Army Knife of Cloud Storage

Rclone is a command-line program to manage files on cloud storage. It is a feature-rich alternative to cloud vendors' web storage interfaces. Over 70 cloud storage products support rclone including S3 object stores, business & consumer file storage services, and standard transfer protocols.

Rclone has powerful cloud equivalents to the unix commands rsync, cp, mv, mount, ls, ncdu, tree, rm, and cat. It preserves timestamps and verifies checksums at all times. Transfers can be restarted from the last good file.

Official resources: rclone.org | Docs | Commands | Install | Forum | GitHub

Prerequisites

Before using rclone, verify it is installed:

# Check if rclone is installed
rclone --version

# If not found, run the install script:
# See scripts/install.sh in this skill's directory
sudo -v ; curl https://rclone.org/install.sh | sudo bash

# Or for beta version:
sudo -v ; curl https://rclone.org/install.sh | sudo bash -s beta

For offline/manual installation, use the bundled script at scripts/install.sh.

Security Warnings

IMPORTANT: Rclone is extremely powerful and can irreversibly modify or delete data on cloud storage. Pay close attention to the following safety guidelines:

  • Always use --dry-run first when running sync, move, delete, or purge commands. This shows what would happen without actually doing it.
  • Use --interactive / -i flag while learning rclone to avoid accidental data loss. It asks for confirmation before each destructive operation.
  • Never expose credentials in plain text on the command line. Use rclone config to store credentials securely, or use environment variables.
  • Private keys and tokens (S3 secret keys, service account JSON, OAuth tokens) must never be committed to version control or logged. The config file ~/.config/rclone/rclone.conf contains sensitive data — protect it with chmod 600.
  • rclone purge ignores all filters — it deletes everything under the specified path. Use with extreme caution.
  • rclone sync makes dest identical to source — files in dest that are not in source will be DELETED. Always verify with --dry-run first.
  • Remote control API (--rc) should bind to localhost only by default. Exposing it without authentication (--rc-htpasswd) allows anyone to control your rclone instance.
  • Mount operations can cause data loss if the mount is interrupted during writes. Use --vfs-cache-mode full for safer writes.

Quick Reference

Configuration

# Interactive configuration (recommended)
rclone config

# Show current config (redacts secrets by default)
rclone config show

# Show full config including secrets (DANGEROUS — do not share output)
rclone config show --redacted=false

# List configured remotes
rclone listremotes

# Create a remote non-interactively
rclone config create myremote s3 provider=AWS env_auth=true region=us-east-1

# Update existing remote
rclone config update myremote region=us-west-2

Basic Syntax

rclone subcommand [options] source:path dest:path

Source and destination paths use remote:path syntax. For local paths, just use /path/to/dir.

Core Commands

# List files
rclone ls remote:path                    # list all objects with size
rclone lsd remote:path                   # list directories
rclone lsl remote:path                   # list with size, modtime, path
rclone lsf remote:path                   # list in flexible format
rclone size remote:path                  # total size and object count
rclone tree remote:path                  # tree view

# Copy (does not delete files at destination)
rclone copy /local/path remote:path      # local to remote
rclone copy remote:path /local/path      # remote to local
rclone copy remote1:path remote2:path    # remote to remote (server-side if possible)

# Sync (makes destination identical to source — DELETES extra files at dest)
rclone sync --dry-run /local/path remote:path    # ALWAYS dry-run first!
rclone sync -i /local/path remote:path           # interactive mode

# Move (copies then deletes source)
rclone move /local/path remote:path

# Delete operations
rclone delete remote:path                # delete contents of path
rclone purge remote:path                 # delete path AND all contents (ignores filters!)

# Check integrity
rclone check /local/path remote:path     # compare source and dest
rclone checksum remote:path              # verify checksums
rclone cryptcheck crypt:path             # verify encrypted remote

# Directory operations
rclone mkdir remote:path                 # create directory
rclone rmdir remote:path                 # remove empty directory
rclone rmdirs remote:path                # remove empty directories recursively

# Other useful commands
rclone cat remote:path/file.txt          # output file to stdout
rclone dedupe remote:path                # interactively find/delete duplicates
rclone about remote:                     # get quota information
rclone version                           # show version

Filtering

Filter rules determine which files rclone processes. Always test with --dry-run and -vv.

# Include only specific patterns
rclone copy /src /dst --include "*.jpg"
rclone copy /src /dst --include-from filter-file.txt

# Exclude specific patterns
rclone copy /src /dst --exclude "*.tmp"
rclone copy /src /dst --exclude-from exclude-file.txt

# Use filter rules (preferred when mixing include/exclude)
rclone sync /src /dst --filter "+ *.jpg" --filter "- *"
rclone sync /src /dst --filter-from rules.txt

# Size-based filtering
rclone copy /src /dst --min-size 1M --max-size 10G

# Age-based filtering
rclone copy /src /dst --min-age 7d --max-age 30d

# IMPORTANT: Do NOT mix --include, --exclude, and --filter flags.
# Use --filter exclusively when combining rules.

Filter pattern syntax:

  • * matches any sequence of non-separator characters
  • ** matches any sequence including separators
  • ? matches any single non-separator character
  • {a,b} matches pattern alternatives
  • {{regexp}} matches using Go regexp

Global Flags (Most Common)

# Verbosity
-v                                        # info level
-vv                                       # debug level (shows filter matches)
--log-level LEVEL                         # DEBUG|INFO|NOTICE|ERROR

# Safety
--dry-run                                 # preview without doing anything
-i, --interactive                         # ask before each operation
--ignore-existing                         # skip files that exist at dest
-I, --ignore-times                        # transfer all, ignore modtime/size

# Transfer control
--transfers N                             # parallel transfers (default 4)
--checkers N                              # parallel checks (default 8)
--bwlimit RATE                            # bandwidth limit (e.g. 10M)
--max-transfer SIZE                       # stop after transferring this much
-c, --checksum                            # use checksum instead of modtime
--size-only                               # compare by size only

# Performance
--multi-thread-streams N                  # multi-thread downloads (default 4)
-P, --progress                            # show real-time progress

# Config
--config STRING                           # config file path
-C, --no-check-dest                       # skip dest check on copy

Mount

# Basic mount
rclone mount remote:path /mnt/remote

# Recommended mount with caching
rclone mount remote:path /mnt/remote \
  --vfs-cache-mode full \
  --vfs-cache-max-size 10G \
  --vfs-read-chunk-size 128M

# Unmount
fusermount -u /mnt/remote                # Linux
umount /mnt/remote                        # macOS

Serve

rclone serve http remote:path             # HTTP file server
rclone serve webdav remote:path           # WebDAV server
rclone serve sftp remote:path             # SFTP server
rclone serve ftp remote:path              # FTP server
rclone serve s3 remote:path               # S3-compatible server
rclone serve dlna remote:path             # DLNA media server
rclone serve restic remote:path           # Restic backup backend
rclone serve docker remote:path           # Docker registry

Encryption (Crypt Remote)

# Configure encrypted remote wrapping another remote
rclone config
# Choose "crypt" type, point to an existing remote (e.g., "drive:private")

# Use crypt remote — files are encrypted/decrypted transparently
rclone copy /local/files crypt:path
rclone ls crypt:path

# Check integrity of encrypted files
rclone cryptcheck crypt:path

Detailed Reference Files

For in-depth information, consult these reference files:

These files are converted from the official Hugo-based rclone documentation under testdata/rclone/docs/. Treat any remaining Hugo shortcode or template syntax as a conversion bug: replace it with normal Markdown, a static table, or an official URL before relying on it in an answer.

File Content When to read Official link
references/usage.md Full usage guide: syntax, config, remote paths, options Understanding advanced rclone behavior Docs
references/flags.md Complete global flags reference Looking up specific flag options Flags
references/filtering.md Filtering, includes/excludes, patterns Building complex filter rules Filtering
references/rc.md Remote control / HTTP API Using rclone's API for programmatic control RC API
references/bisync.md Bidirectional sync between two paths Setting up two-way sync Bisync
references/crypt.md Encrypted remote configuration Setting up encrypted cloud storage Crypt
references/cache.md Cache backend and directory caching Optimizing performance with caching Cache
references/chunker.md Transparent file chunking Handling large files on limited remotes Chunker
references/union.md Union backend (merge multiple remotes) Combining multiple storage backends Union
references/combine.md Combine backend (unified namespace) Unified view of multiple remotes Combine
references/hasher.md Hasher backend for checksum handling Adding hash support to remotes Hasher
references/overview.md Cloud storage system feature comparison Comparing provider capabilities Overview
references/install.md Detailed installation instructions Troubleshooting installation Install
references/docker.md Docker usage guide Running rclone in Docker Docker
references/faq.md Frequently asked questions Troubleshooting common issues FAQ
references/commands/ Individual command documentation Detailed command usage Commands

Popular Provider References

For configuring specific cloud storage providers, read the corresponding file in references/providers/ when present. Some virtual/backing providers, such as crypt, cache, chunker, union, combine, and hasher, live as top-level files in references/ because they are cross-provider backends rather than single cloud services.

  • s3.md — Amazon S3 / compatible (Official)
  • drive.md — Google Drive (Official)
  • dropbox.md — Dropbox (Official)
  • onedrive.md — Microsoft OneDrive (Official)
  • azureblob.md — Azure Blob Storage (Official)
  • b2.md — Backblaze B2 (Official)
  • googlecloudstorage.md — Google Cloud Storage (Official)
  • sftp.md — SFTP (Official)
  • webdav.md — WebDAV (Official)
  • swift.md — OpenStack Swift (Official)
  • ftp.md — FTP (Official)
  • And 60+ more providers — each has a page at https://rclone.org/<name>/

Command References

For detailed command documentation, read the corresponding file in references/commands/:

  • rclone_copy.md, rclone_sync.md, rclone_move.md — transfer commands
  • rclone_mount.md — FUSE mount
  • rclone_serve_*.md — various serve modes
  • rclone_config*.md — configuration management
  • rclone_bisync.md — bidirectional sync
  • And 80+ more commands — each has a page at https://rclone.org/commands/<command>/

Common Workflows

Initial Setup

rclone config          # interactive setup wizard
rclone lsd remote:     # verify connection works

Backup Local to Cloud

rclone sync --dry-run -P /home/user/documents remote:backup/documents
# Review dry-run output carefully, then:
rclone sync -P /home/user/documents remote:backup/documents

Cloud-to-Cloud Migration

rclone copy --dry-run -P source_remote:path dest_remote:path
rclone copy -P --transfers 8 source_remote:path dest_remote:path

Restore from Cloud

rclone copy --dry-run remote:backup/documents /home/user/restored
rclone copy -P remote:backup/documents /home/user/restored

Bandwidth-Limited Transfer

rclone copy --bwlimit 10M -P /data remote:backup

Encrypted Backup

# First configure a crypt remote wrapping your storage remote
rclone config
# Then use the crypt remote for all operations
rclone sync -P /sensitive-data crypt:backup

Scheduled Backup (cron)

# Add to crontab (daily at 2am):
0 2 * * * rclone sync -P /data remote:backup >> /var/log/rclone.log 2>&1
Install via CLI
npx skills add https://github.com/chaunsin/agent-skills --skill rclone-cli
Repository Details
star Stars 1
call_split Forks 0
navigation Branch main
article Path SKILL.md
More from Creator