1 This patch adds a --slow-down=USECs option that causes the sender to scan
2 the filelist more slowly, and the generator to scan for deletions more
3 slowly. It doesn't do anything to make anyone slow down during the normal
4 transfer processing, though.
6 The idea is to lessen rsync's impact on disk I/O. Unfortunately, there
7 should really be a way to affect more of rsync's processing, perhaps by
8 specifying a maximum disk I/O rate (and have that affect a maximum stat()
9 rate or something like that).
11 To use this patch, run these commands for a successful build:
13 patch -p1 <patches/slow-down.diff
14 ./configure (optional if already run)
17 based-on: a01e3b490eb36ccf9e704840e1b6683dab867550
18 diff --git a/flist.c b/flist.c
21 @@ -72,6 +72,7 @@ extern int sender_symlink_iconv;
22 extern int output_needs_newline;
23 extern int sender_keeps_checksum;
24 extern int unsort_ndx;
25 +extern unsigned long sleep_asec;
26 extern struct stats stats;
27 extern char *filesfrom_host;
28 extern char *usermap, *groupmap;
29 @@ -1754,6 +1755,9 @@ static void send_directory(int f, struct file_list *flist, char *fbuf, int len,
32 send_file_name(f, flist, fbuf, NULL, flags, filter_level);
33 + /* Sleep for a bit, to avoid hammering the disk. */
39 diff --git a/options.c b/options.c
42 @@ -108,6 +108,7 @@ int size_only = 0;
43 int daemon_bwlimit = 0;
46 +unsigned long sleep_asec = 0;
47 size_t bwlimit_writemax = 0;
48 int ignore_existing = 0;
49 int ignore_non_existing = 0;
50 @@ -776,6 +777,7 @@ void usage(enum logcode F)
51 rprintf(F," --password-file=FILE read daemon-access password from FILE\n");
52 rprintf(F," --list-only list the files instead of copying them\n");
53 rprintf(F," --bwlimit=RATE limit socket I/O bandwidth\n");
54 + rprintf(F," --slow-down=USECs sleep N usec while creating the filelist\n");
55 rprintf(F," --write-batch=FILE write a batched update to FILE\n");
56 rprintf(F," --only-write-batch=FILE like --write-batch but w/o updating destination\n");
57 rprintf(F," --read-batch=FILE read a batched update from FILE\n");
58 @@ -964,6 +966,7 @@ static struct poptOption long_options[] = {
59 {"itemize-changes", 'i', POPT_ARG_NONE, 0, 'i', 0, 0 },
60 {"no-itemize-changes",0, POPT_ARG_VAL, &itemize_changes, 0, 0, 0 },
61 {"no-i", 0, POPT_ARG_VAL, &itemize_changes, 0, 0, 0 },
62 + {"slow-down", 0, POPT_ARG_LONG, &sleep_asec, 0, 0, 0 },
63 {"bwlimit", 0, POPT_ARG_STRING, &bwlimit_arg, OPT_BWLIMIT, 0, 0 },
64 {"no-bwlimit", 0, POPT_ARG_VAL, &bwlimit, 0, 0, 0 },
65 {"backup", 'b', POPT_ARG_VAL, &make_backups, 1, 0, 0 },