1File::RsyncP(3) User Contributed Perl Documentation File::RsyncP(3)
2
3
4
6 File::RsyncP - Perl Rsync client
7
9 use File::RsyncP;
10
11 my $rs = File::RsyncP->new({
12 logLevel => 1,
13 rsyncCmd => "/bin/rsync",
14 rsyncArgs => [
15 "--numeric-ids",
16 "--perms",
17 "--owner",
18 "--group",
19 "--devices",
20 "--links",
21 "--ignore-times",
22 "--block-size=700",
23 "--relative",
24 "--recursive",
25 "-v",
26 ],
27 });
28
29 #
30 # Receive files from remote srcDirectory to local destDirectory
31 # by running rsyncCmd with rsyncArgs.
32 #
33 $rs->remoteStart(1, srcDirectory);
34 $rs->go(destDirectory);
35 $rs->serverClose;
36
37 #
38 # Send files to remote destDirectory from local srcDirectory
39 # by running rsyncCmd with rsyncArgs.
40 #
41 $rs->remoteStart(0, destDirectory);
42 $rs->go(srcDirectory);
43 $rs->serverClose;
44
45 #
46 # Receive files from a remote module to local destDirectory by
47 # connecting to an rsyncd server. ($module is the name from
48 # /etc/rsyncd.conf.)
49 #
50 my $port = 873;
51 $rs->serverConnect($host, $port);
52 $rs->serverService($module, $authUser, $authPasswd, 0);
53 $rs->serverStart(1, ".");
54 $rs->go(destDirectory);
55 $rs->serverClose;
56
57 #
58 # Get finals stats. This is a hashref containing elements
59 # totalRead, totalWritten, totalSize, plus whatever the FileIO
60 # module might add.
61 #
62 my $stats = $rs->statsFinal;
63
65 File::RsyncP is a perl implementation of an Rsync client. It is
66 compatible with Rsync 2.5.5 - 2.6.3 (protocol versions 26-28). It can
67 send or receive files, either by running rsync on the remote machine,
68 or connecting to an rsyncd deamon on the remote machine.
69
70 What use is File::RsyncP? The main purpose is that File::RsyncP
71 separates all file system I/O into a separate module, which can be
72 replaced by any module of your own design. This allows rsync
73 interfaces to non-filesystem data types (eg: databases) to be developed
74 with relative ease.
75
76 File::RsyncP was initially written to provide an Rsync interface for
77 BackupPC, <http://backuppc.sourceforge.net>. See BackupPC for
78 programming examples.
79
80 File::RsyncP does not yet provide a command-line interface that mimics
81 native Rsync. Instead it provides an API that makes it possible to
82 write simple scripts that talk to rsync or rsyncd.
83
84 The File::RsyncP::FileIO module contains the default file system access
85 functions. File::RsyncP::FileIO may be subclassed or replaced by a
86 custom module to provide access to non-filesystem data types.
87
88 Getting Started
89 First some background. When you run rsync is parses its command-line
90 arguments, then it either connects to a remote rsyncd daemon, or runs
91 an rsync on the remote machine via ssh or rsh. At this point there are
92 two rsync processes: the one you invoked and the one on the remote
93 machine. The one on the local machine is called the client, and the
94 one on the remote machine is the server. One side (either the client
95 or server) will send files and the other will receive files. The
96 sending rsync generates a file list and sends it to the receiving side.
97 The receiving rsync will fork a child process.
98
99 File::RsyncP does not (yet) have a command-line script that mimics
100 rsync's startup processing. Think of File::RsyncP as one level below
101 the command-line rsync. File::RsyncP implements the client side of the
102 connection, and File::RsyncP knows how to run the remote side (eg, via
103 rsh or ssh) or to connect to a remote rsyncd daemon. File::RsyncP
104 automatically adds the internal --server and --sender options (if
105 necessary) to the options passed to the remote rsync.
106
107 To initiate any rsync session the File::RsyncP->new function should be
108 called. It takes a hashref of parameters:
109
110 logLevel
111 An integer level of verbosity. Zero means be quiet, 1 will give
112 some general information, 2 will some output per file, higher
113 values give more output. 10 will include byte dumps of all data
114 read/written, which will make the log output huge.
115
116 rsyncCmd
117 The command to run the remote peer of rsync. By default the
118 rsyncArgs are appended to the rsyncCmd to create the complete
119 command before it is run. This behavior is affected by
120 rsyncCmdType.
121
122 rsyncCmd can either be a single string giving the path of the rsync
123 command to run (eg: /bin/rsync) or a list containing the command
124 and arguments, eg:
125
126 rsyncCmd => [qw(
127 /bin/ssh -l user host /bin/rsync
128 )],
129
130 or:
131
132 rsyncCmd => ["/bin/ssh", "-l", $user, $host, "/bin/rsync"],
133
134 Also, rsyncCmd can also be set to a code reference (ie: a perl
135 sub). In this case the code is called without arguments or other
136 processing. It is up to the perl code you supply to exec() the
137 remote rsync.
138
139 This option is ignored if you are connecting to an rsyncd daemon.
140
141 rsyncCmdType
142 By default the complete remote rsync command is created by taking
143 rsyncCmd and appending rsyncArgs. This beavhior can be modified by
144 specifying certain values for rsyncCmdType:
145
146 'full'
147 rsyncCmd is taken to be the complete command, including all
148 rsync arguments. It is the caller's responsibility to build
149 the correct remote rsync command, togheter will all the rsync
150 arguments. You still need to specify rsyncArgs, so the local
151 File::RsyncP knows how to behave.
152
153 'shell'
154 rsyncArgs are shell escaped before appending to rsyncCmd.
155
156 This option is ignored if you are connecting to an rsyncd daemon.
157
158 rsyncArgs
159 A list of rsync arguments. The full remote rsync command that is
160 run will be rsyncCmd appended with --server (and optionally
161 --sender if the remote is a sender) and finally all of rsyncArgs.
162
163 protocol_version
164 What we advertize our protocol version to be. Default is 28.
165
166 logHandler
167 A subroutine reference to a function that handles all the log
168 messages. The default is a subroutine that prints the messages to
169 STDERR.
170
171 pidHandler
172 An optional subroutine reference to a function that expects two
173 integers: the pid of the rsync process (ie: the pid on the local
174 machine that is likely ssh) and the child pid when we are receiving
175 files. If defined, this function is called once when the rsync
176 process is forked, and again when the child is forked during
177 receive.
178
179 fio The file IO object that will handle all the file system IO. The
180 default is File::RsyncP::FileIO->new.
181
182 This can be replaced with a new module of your choice, or you can
183 subclass File::RsyncP::FileIO.
184
185 timeout
186 Timeout in seconds for IO. Default is 0, meaning no timeout. Uses
187 alarm() and it is the caller's responsbility to catch the alarm
188 signal.
189
190 doPartial
191 If set, a partial rsync is done. This is to support resuming full
192 backups in BackupPC. When doPartial is set, the --ignore-times
193 option can be set on a per-file basis. On each file in the file
194 list, File::RsyncP::FileIO->ignoreAttrOnFile() is called on each
195 file, and this returns whether or not attributes should be ignored
196 on that file. If ignoreAttrOnFile() returns 1 then it's as though
197 --ignore-times was set for that file.
198
199 An example of calling File::RsyncP->new is:
200
201 my $rs = File::RsyncP->new({
202 logLevel => 1,
203 rsyncCmd => ["/bin/rsh", $host, "-l", $user, "/bin/rsync"],
204 rsyncArgs => [
205 "--numeric-ids",
206 "--perms",
207 "--owner",
208 "--group",
209 "--devices",
210 "--links",
211 "--ignore-times",
212 "--block-size=700",
213 "--relative",
214 "--recursive",
215 "-v",
216 ],
217 });
218
219 A fuller example showing most of the parameters and qw() for the
220 rsyncArgs is:
221
222 my $rs = File::RsyncP->new({
223 logLevel => 1,
224 rsyncCmd => ["/bin/rsh", $host, "-l", $user, "/bin/rsync"],
225 rsyncArgs => [qw(
226 --numeric-ids
227 --perms
228 --owner
229 --group
230 --devices
231 --links
232 --ignore-times
233 --block-size=700
234 --relative
235 --recursive
236 -v
237 )],
238 logHandler => sub {
239 my($str) = @_;
240 print MyHandler "log: $str\n";
241 };
242 fio => File::RsyncP::FileIO->new({
243 logLevel => 1,
244 });
245
246 });
247
248 Talking to a remote Rsync
249 File::RsyncP can talk to a remote rsync using this sequence of
250 functions:
251
252 remoteStart(remoteSend, remoteDir)
253 Starts the remote server by executing the command specified in the
254 rsyncCmd parameter to File::RsyncP->new, together with the
255 rsyncArgs.
256
257 If the client is receiving files from the server then remoteSend
258 should be non-zero and remoteDir is the source directory on the
259 remote machine. If the client is sending files to the remote
260 server then remoteSend should be zero and remoteDir is the
261 destination directory on the remote machine. Returns undef on
262 success and non-zero on error.
263
264 go(localDir)
265 Run the client rsync. localDir is the source directory on the
266 local machine if the client is sending files, or it is the
267 destination directory on the local machine if the client is
268 receiving files. Returns undef on success.
269
270 serverClose()
271 Call this after go() to finish up. Returns undef on success.
272
273 statsFinal()
274 This can be optionally called to pickup the transfer stats. It
275 returns a hashref containing elements totalRead, totalWritten,
276 totalSize, plus whatever the FileIO module might add.
277
278 abort()
279 Call this function to abort the transfer.
280
281 An example of sending files to a remote rsync is:
282
283 #
284 # Send files to remote destDirectory from local srcDirectory
285 # by running rsyncCmd with rsyncArgs.
286 #
287 $rs->remoteStart(0, destDirectory);
288 $rs->go(srcDirectory);
289 $rs->serverClose;
290
291 An example of receiving files from a remote rsync is:
292
293 #
294 # Receive files from remote srcDirectory to local destDirectory
295 # by running rsyncCmd with rsyncArgs.
296 #
297 $rs->remoteStart(1, srcDirectory);
298 $rs->go(destDirectory);
299 $rs->serverClose;
300
301 Talking to a remote Rsync daemon
302 File::RsyncP can connect to a remote Rsync daemon using this sequence
303 of functions:
304
305 serverConnect(host, port)
306 Connect to the Rsync daemon on the given string host and integer
307 port. The port argument is optional and it defaults to 873. On
308 error serverConnect returns a string error message. On success it
309 returns undef.
310
311 serverService(module, authUser, authPasswd, authRequired)
312 Specify which module to use (a "module" is the symbolic name that
313 appears inside "[...]" /etc/rsyncd.conf), the user's credentials
314 (authUser and authPasswd) and whether authorization is mandatory
315 (authRequired). If set to a non-zero value, authRequired ensures
316 that the remote Rsync daemon requires authentication. If
317 necessary, this is to ensure that you don't connect to an insecure
318 Rsync daemon. The auth arguments are optional if the selected
319 rsyncd module doesn't require authentication.
320
321 See the rsyncd.conf manual page for more information. For example,
322 if a host called navajo had a /etc/rsyncd.conf contains these
323 lines:
324
325 [test]
326 path = /data/test
327 comment = test module
328 auth users = craig, celia
329 secrets file = /etc/rsyncd.secrets
330
331 and /etc/rsyncd.secrets contained:
332
333 craig:xxx
334
335 then you could connect to this rsyncd using:
336
337 $rs->serverConnect("navajo", 873);
338 $rs->serverService("test", "craig", "xxx", 0);
339
340 The value of the authRequired argument doesn't matter in this case.
341
342 On error serverService returns a string error message. On success
343 it returns undef.
344
345 serverStart(remoteSend, remoteDir)
346 Starts the remote server. If the client is receiving files from
347 the server then remoteSend should be non-zero. If the client is
348 sending files to the remote server then remoteSend should be zero.
349 The remoteDir typically starts with the module name, followed by
350 any directory below the module. Or remoteDir can be just "." to
351 refer to the top-level module directory. Returns undef on success.
352
353 go(localDir)
354 Run the client rsync. localDir is the source directory on the
355 local machine if the client is sending files, or it is the
356 destination directory on the local machine if the client is
357 receiving files. Returns undef on success.
358
359 serverClose()
360 Call this after go() to finish up. Returns undef on success.
361
362 abort()
363 Call this function to abort the transfer.
364
365 An example of sending files to a remote rsyncd daemon is:
366
367 #
368 # Send files to a remote module from a local srcDirectory by
369 # connecting to an rsyncd server. ($module is the name from
370 # /etc/rsyncd.conf.)
371 #
372 my $port = 873;
373 $rs->serverConnect($host, $port);
374 $rs->serverService($module, $authUser, $authPasswd);
375 $rs->serverStart(0, ".");
376 $rs->go(srcDirectory);
377 $rs->serverClose;
378
379 An example of receiving files from a remote rsyncd daemon is:
380
381 #
382 # Receive files from a remote module to local destDirectory by
383 # connecting to an rsyncd server. ($module is the name from
384 # /etc/rsyncd.conf.)
385 #
386 my $port = 873;
387 $rs->serverConnect($host, $port);
388 $rs->serverService($module, $authUser, $authPasswd);
389 $rs->serverStart(1, ".");
390 $rs->go(destDirectory);
391 $rs->serverClose;
392
394 The initial version of File::RsyncP (0.10) has a number of limitations:
395
396 • File::RsyncP only implements a modest subset of Rsync options and
397 features. In particular, as of 0.10 only these options are
398 supported:
399
400 --numeric-ids
401 --perms|-p
402 --owner|-o
403 --group|-g
404 --devices|D
405 --links|-l
406 --ignore-times|I
407 --block-size=i
408 --verbose|-v
409 --recursive|-r
410 --relative|-R
411
412 Hardlinks are currently not supported. Other options that only
413 affect the remote side will work correctly since they are passed to
414 the remote Rsync unchanged.
415
416 • Also, --relative semantics are not implemented to match rsync, and
417 the trailing "/" behavior of rsync (meaning directory contents, not
418 the directory itself) are not implemented in File::RsyncP.
419
420 • File::RsyncP does not yet provide a command-line interface that
421 mimics native Rsync.
422
423 • File::RsyncP might work with slightly earlier versions of Rsync but
424 has not been tested. It certainly will not work with antique
425 versions of Rsync.
426
427 • File::RsyncP does not compute file deltas (ie: it behaves as though
428 --whole-file is specified) or implement exclude or include options
429 when sending files. File::RsyncP does handle file deltas and
430 exclude and include options when receiving files.
431
432 • File::RsyncP does not yet implement server functionality (acting
433 like the remote end of a connection or a daemon). Since the
434 protocol is relatively symmetric this is not difficult to add, so
435 it should appear in a future version.
436
438 File::RsyncP::FileList was written by Craig Barratt
439 <cbarratt@users.sourceforge.net> based on rsync 2.5.5.
440
441 Rsync was written by Andrew Tridgell <tridge@samba.org> and Paul
442 Mackerras. It is available under a GPL license. See
443 http://rsync.samba.org.
444
446 This program is free software; you can redistribute it and/or modify it
447 under the terms of the GNU General Public License as published by the
448 Free Software Foundation; either version 2 of the License, or (at your
449 option) any later version.
450
451 This program is distributed in the hope that it will be useful, but
452 WITHOUT ANY WARRANTY; without even the implied warranty of
453 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
454 General Public License for more details.
455
456 You should have received a copy of the GNU General Public License in
457 the LICENSE file along with this program; if not, write to the Free
458 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
459 02111-1307 USA.
460
462 See <http://perlrsync.sourceforge.net> for File::RsyncP's SourceForge
463 home page.
464
465 See File::RsyncP::FileIO, File::RsyncP::Digest, and
466 File::RsyncP::FileList.
467
468 Also see BackupPC's lib/BackupPC/Xfer/Rsync.pm for other examples.
469
470
471
472perl v5.34.0 2022-03-22 File::RsyncP(3)