mirror of https://github.com/CrimsonTome/tldr.git
38 lines
1.6 KiB
Markdown
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_directory}} {{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}}`
|