Crates.io | rjrssync |
lib.rs | rjrssync |
version | 0.2.7 |
source | src |
created_at | 2022-12-29 18:58:38.336286 |
updated_at | 2023-02-19 21:23:38.93198 |
description | Fast rsync-like tool for incrementally copying files. Runs natively on both Windows and Linux and uses network for communication. |
homepage | |
repository | https://github.com/Robert-Hughes/rjrssync |
max_upload_size | |
id | 747487 |
size | 673,542 |
Fast rsync-like tool for incrementally copying files. Runs natively on both Windows and Linux and uses network for communication, to maximise speed when syncing between Windows and WSL filesystems.
/mnt/
or \\wsl$\
Pre-built binaries are available, or you can build from source.
Binaries are available for some platforms from the latest release page.
You can also install using cargo binstall, which will automatically download these same binaries:
cargo binstall rjrssync
cargo install rjrssync
This will download the latest release of the source code from crates.io, build and then install rjrssync.
This default build configuration will not include cross-compiled binaries for other platforms, and so rjrssync will not be able to sync to remote targets that are running different OSes or architectures. If you want to enable this feature, then some additional build steps are needed:
cargo install --features=embed-all rjrssync
As part of this build, rjrssync is also cross-compiled for several other platforms and these are embedded into the final binary. You may need to set up your build environment for this to work, for example adding some additional targets to rustup
:
sudo apt install mingw-w64
rustup target add x86_64-pc-windows-gnu
rustup target add x86_64-unknown-linux-musl
rustup target add aarch64-unknown-linux-musl
rustup target add x86_64-unknown-linux-musl
rustup target add aarch64-unknown-linux-musl
A quick example:
rjrssync local-folder/ user@hostname:/remote/folder
rjrssync uses ssh
to estabilish an initial connection to the remote host but then switches to its own protocol to maximize performance. The first time that a remote host is used, rjrssync will deploy a pre-built binary to the remote host, which will be launched whenever rjrssync connects to that host. You will be prompted before this deployment happens. rjrssync's protocol is encrypted and authenticated using AES-GCM with a 128-bit key and 96-bit nonce. It operates over TCP and so needs an open network port that the local copy can connect to the remote copy on. By default it automatically chooses a free port, but this can be overridden using --remote-port
. You may need to adjust your firewall settings to allow this connection.
See rjrssync --help
for more.
There are also some less well-presented notes on various features here.