1 # NEWS for rsync 3.2.0 (UNRELEASED)
3 Protocol: 31 (unchanged)
5 ## Changes since 3.1.3:
9 - Avoid a potential out-of-bounds read in daemon mode if argc can be made to
12 - Fix the default list of skip-compress files for non-daemon transfers.
14 - Fix xattr filter rules losing an 'x' attribute in a non-local transfer.
16 - Avoid an error when a check for a potential fuzzy file happens to reference
19 - Make the atomic-rsync helper script have a more consistent error-exit.
21 - Make sure that a signal handler calls `_exit()` instead of exit().
23 - Various zlib fixes, including security fixes for CVE-2016-9843,
24 CVE-2016-9842, CVE-2016-9841, and CVE-2016-9840.
26 - Fixed an issue with `--remove-source-files` not removing a source symlink
27 when combined with `--copy-links`.
29 - Fixed a bug where the daemon would fail to write early fatal error messages
30 to the client, such as refused or unknown command-line options.
32 - Fixed the block-size validation logic when dealing with older protocols.
34 - Some rrsync fixes and enhancements to handle the latest options.
36 - Fixed a crash in the `--iconv` code.
38 - Fixed a problem with the `--link-dest`|`--copy-dest` code when `--xattrs`
39 was specified along with multiple alternate-destination directories (it
40 could possibly choose a bad file match while trying to find a better xattr
43 - Fixed a couple bugs in the handling of files with the `--sparse` option.
45 - Fixed a bug in the writing of the batch.sh file (w/--write-batch) when the
46 source & destination args were not last on the command-line.
48 - Avoid a hang when an overabundance of messages clogs up all the I/O buffers.
50 - Fixed a mismatch in the RSYNC_PID values when running both a `pre-xfer exec`
51 and a `post-xfer exec`.
55 - Various checksum enhancements, including the optional use of openssl's MD4 &
56 MD5 checksum algorithms, some x86-64 optimizations for the rolling checksum,
57 some x86-64 optimizations for the (non-openssl) MD5 checksum, the addition
58 of xxhash checksum support, and a negotiation heuristic that ensures that it
59 is easier to add new checksum algorithms in the future. Currently the
60 x86-64 optimizations require the use of the `--enable-simd` flag to
61 configure, but they will probably be enabled by default in the near future.
62 The environment variable `RSYNC_CHECKSUM_LIST` can be used to customize the
63 preference order of the negotiation.
65 - Various compression enhancements, including the addition of zstd and lz4
66 compression algorithms and a negotiation heuristic that picks the best
67 compression option supported by both sides. The environment variable
68 `RSYNC_COMPRESS_LIST` can be used to customize the preference order of the
69 heuristic when speaking to another rsync 3.2.0 version.
71 - Added a --debug=NSTR option that outputs details of the new negotiation
72 strings (for checksums and compression). The first level just outputs the
73 result of each negotiation on the client, level 2 outputs the values of the
74 strings that were sent to and received from the server, and level 3 outputs
75 all those values on the server side too.
77 - The --debug=OPTS command-line option is no longer auto-forwarded to the
78 remote rsync which allows for the client and server to have different levels
79 of debug specified. This also allows for newer debug options to be
80 specified, such as using --debug=NSTR to see the negotiated hash result,
81 without having the command fail if the server version is too old to handle
82 that debug item. Use -M--debug=OPTS to send the options to the remote side.
84 - Added the `--atimes` option based on the long-standing patch (just with some
85 fixes that the patch has been needing).
87 - Added `--open-noatime` option to open files using `O_NOATIME`.
89 - Added the `--write-devices` option based on the long-standing patch.
91 - Added openssl support to the rsync-ssl script, which is now installed by
92 default. This script was unified with the stunnel-rsync helper script to
95 - Rsync was enhanced to set the `RSYNC_PORT` environment variable when running
96 a daemon-over-rsh script. Its value is the user-specified port number (set
97 via `--port` or an rsync:// URL) or 0 if the user didn't override the port.
99 - Added the `haproxy header` daemon parameter that allows your rsyncd to know
100 the real remote IP when it is being proxied.
102 - Added negated matching to the daemon's `refuse options` setting by using
103 match strings that start with a `!` (such as `!compress*`).
105 - Added the `early exec` daemon parameter that runs a script before the
106 transfer parameters are known, allowing some early setup based on module
109 - Added status output in response to a signal (via both SIGINFO & SIGVTALRM).
111 - Added a `--copy-as=USER` option to give some extra security to root-run
112 rsync commands into/from untrusted directories (such as backups and
115 - When resuming the transfer of a file in the `--partial-dir`, rsync will now
116 update that partial file in-place instead of creating yet another tmp file
117 copy. This requires both sender & receiver to be at least v3.2.0.
119 - Added support for `RSYNC_SHELL` & `RSYNC_NO_XFER_EXEC` environment variables
120 that affect the pre-xfer exec and post-xfer exec rsync daemon options.
122 - Optimize the `--fuzzy` `--fuzzy` heuristic to avoid the fuzzy directory scan
123 until all other basis-file options are exhausted (such as `--link-dest`).
125 - Have a daemon that is logging include the normal-exit sent/received stats
126 even when the transfer exited with an error.
128 - The daemon now locks its pid file (when configured to use one) so that it
129 will not fail to start when the file exists and it is unlocked.
131 - Various man page improvements.
133 - Made -V the short option for --version.
135 ### PACKAGING RELATED:
137 - Add installed binary: /usr/bin/rsync-sll
139 - Add installed man page: /usr/man/man1/rsync-ssl.1
141 - The rsync-ssl script wants to run either openssl or stunnel4, so consider
142 adding a dependency for openssl (though it's probably fine to just let it
143 complain about being unable to find either program and let the user decide
144 if they want to install one or the other).
146 - If you packaged rsync + rsync-ssl + rsync-ssl-daemon as separate packages,
147 the rsync-ssl package is now gone (along with its install-ssl-client make
148 target -- rsync-ssl should be considered to be mainstream now that Samba
149 requires SSL for its rsync daemon).
151 - Add _build_ dependency for liblz4-devel, libxxhash-devel, & libzstd-devel.
152 These development libraries will give rsync extra compression and checksum
155 - Remove yodl _build_ dependency (if you listed it).
157 - Add _build_ dependency for _either_ python3-cmarkcfm or python3-commonmark
158 to allow for patching of man pages or building a git release. Note that
159 cmarkcfm is faster than commonmark, but they generate the same data.
161 ### DEVELOPER RELATED:
163 - Silenced some annoying warnings about major()|minor() due to the autoconf
164 include-file check not being smart enough.
166 - Converted the man pages from yodl to markdown. They are now processed via a
167 simple python3 script using the cmarkgfm OR commonmark library. This should
168 make it easier for packaging rsync, since yodl has gotten obscure.
170 - Improved some configure checks to work better with strict C99 compilers.
172 - The `--debug=FOO` options are no longer auto-forwarded to the server side,
173 allowing more control over what is output & the ability to request debug
174 data from divergent rsync versions.
176 - Some perl scripts were recoded into awk and python3.
178 - Some defines in byteorder.h were changed into static inline functions that
179 will help to ensure that the args don't get evaluated multiple times on
180 `careful alignment` hosts.
182 - Some code typos were fixed (as pointed out by a Fossies run).
184 ------------------------------------------------------------------------------