rsync.md 1.6 KB

rsync

Transfer files either to or from a remote host (but not between two remote hosts), by default using SSH. To specify a remote path, use user@host:path/to/file_or_directory. More information: https://download.samba.org/pub/rsync/rsync.1.

  • Transfer a file:

rsync {{path/to/source}} {{path/to/destination}}

  • Use archive mode (recursively copy directories, copy symlinks without resolving, and preserve permissions, ownership and modification times):

rsync {{[-a|--archive]}} {{path/to/source}} {{path/to/destination}}

  • Compress the data as it is sent to the destination, display verbose and human-readable progress, and keep partially transferred files if interrupted:

rsync {{[-zvhP|--compress --verbose --human-readable --partial --progress]}} {{path/to/source}} {{path/to/destination}}

  • Recursively copy directories:

rsync {{[-r|--recursive]}} {{path/to/source}} {{path/to/destination}}

  • Transfer directory contents, but not the directory itself:

rsync {{[-r|--recursive]}} {{path/to/source/}} {{path/to/destination}}

  • Use archive mode, resolve symlinks, and skip files that are newer on the destination:

rsync {{[-auL|--archive --update --copy-links]}} {{path/to/source}} {{path/to/destination}}

  • Transfer a directory from a remote host running rsyncd and delete files on the destination that do not exist on the source:

rsync {{[-r|--recursive]}} --delete rsync://{{host}}:{{path/to/source}} {{path/to/destination}}

  • Transfer a file over SSH using a different port than the default (22) and show global progress:

rsync {{[-e|--rsh]}} 'ssh -p {{port}}' --info=progress2 {{host}}:{{path/to/source}} {{path/to/destination}}