tldr/pages/common/rsync.md

38 lines
1.6 KiB
Markdown

# rsync
> Transfer files either to or from a remote host (not between two remote hosts).
> Can transfer single files, or multiple files matching a pattern.
> More information: <https://manned.org/rsync>.
- Transfer file from local to remote host:
`rsync {{path/to/local_file}} {{remote_host}}:{{path/to/remote_directory}}`
- Transfer file from remote host to local:
`rsync {{remote_host}}:{{path/to/remote_file}} {{path/to/local_directory}}`
- Transfer file in [a]rchive (to preserve attributes) and compressed ([z]ipped) mode with [v]erbose and [h]uman-readable [P]rogress:
`rsync -azvhP {{path/to/local_file}} {{remote_host}}:{{path/to/remote_directory}}`
- Transfer a directory and all its children from a remote to local:
`rsync -r {{remote_host}}:{{path/to/remote_directory}} {{path/to/local_directory}}`
- Transfer directory contents (but not the directory itself) from a remote to local:
`rsync -r {{remote_host}}:{{path/to/remote_directory}}/ {{path/to/local_directory}}`
- Transfer a directory [r]ecursively, in [a]rchive to preserve attributes, resolving contained soft[l]inks , and ignoring already transferred files [u]nless newer:
`rsync -rauL {{remote_host}}:{{path/to/remote_file}} {{path/to/local_directory}}`
- Transfer file over SSH and delete remote files that do not exist locally:
`rsync -e ssh --delete {{remote_host}}:{{path/to/remote_file}} {{path/to/local_file}}`
- Transfer file over SSH using a different port than the default and show global progress:
`rsync -e 'ssh -p {{port}}' --info=progress2 {{remote_host}}:{{path/to/remote_file}} {{path/to/local_file}}`