File: examples.adoc

package info (click to toggle)
rdiff-backup 2.2.6-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,640 kB
  • sloc: python: 24,129; javascript: 9,512; sh: 1,230; ansic: 580; makefile: 36
file content (291 lines) | stat: -rw-r--r-- 11,504 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
= rdiff-backup: {page-name}
:page-name: Examples
:sectnums:
:toc: macro

link:.[Home,role="button round"] // *{page-name}*

'''''

toc::[]


== Old vs New Command Line Interface

Starting with `rdiff-backup` version 2.1, there have been two separate syntaxes for the command line interface, differentiated by the `--new` flag.
Legacy CLI commands follow the syntax `rdiff-backup [options…] [source…] [destination…]`, while the new CLI uses the syntax `rdiff-backup [global options…] action [action-specific options…] [locations…]`.
The functionality of the commands are the same, but for completeness the examples in this document will be given in both the old and new syntax side-by-side.

== Backing up

Simplest case: backup local directory `foo` to local directory `bar`.
`bar` will end up a copy of `foo`, except it will contain the directory foo/rdiff-backup-data, which will allow rdiff-backup to restore previous states.

----
rdiff-backup foo bar

rdiff-backup backup foo bar
----

Simple remote case: backup directory `/some/local-dir` to the directory `/whatever/remote-dir` on the machine hostname.net.
It uses ssh to open the necessary pipe to the remote copy of rdiff-backup.
Just like the above except one directory is on a remote computer.

----
rdiff-backup /some/local-dir hostname.net::/whatever/remote-dir

rdiff-backup backup /some/local-dir hostname.net::/whatever/remote-dir
----

This time the source directory is remote and the destination is local.
Also, we have specified the username on the remote host (by default ssh will attempt to log you in with the same username you have on the local host).

----
rdiff-backup user@hostname.net::/remote-dir local-dir

rdiff-backup backup user@hostname.net::/remote-dir local-dir
----

It is even possible for both the source and destination directories to be on other machines.
Below we have also added the `-v5` switch for greater verbosity (verbosity settings go from 0 to 9, with 3 as the default), and the `--print-statistics` switch so some statistics will be displayed at the end (even without this switch, the statistics will still be saved in the `rdiff-backup-data` directory).

----
rdiff-backup -v5 --print-statistics user1@host1::/source-dir user2@host2::/dest-dir

rdiff-backup -v5 backup --print-statistics user1@host1::/source-dir user2@host2::/dest-dir
----

== Restoring

Suppose earlier we have run `rdiff-backup foo bar`, with both foo and bar local.
We accidentally deleted `foo/dir` and now want to restore it from `bar/dir`.

----
cp -a bar/dir foo/dir
----

That's right, since rdiff-backup makes a mirror, we can retrieve files using standard commands like `cp`.

For the rest of the examples in the section, we will assume that the user has backed up with the command `rdiff-backup local-dir host.net::/remote-dir`.
Of course, in all these examples it would be equally possible to have the source being remote and the backup directory local.

In this case we can't use `cp` to copy `host.net::remote-dir/file` to `local-dir/file` because they are on different machines.
We can get rdiff-backup to restore the current version of that file using either of these:

----
rdiff-backup --restore-as-of now host.net::/remote-dir/file local-dir/file

rdiff-backup -r now host.net::/remote-dir/file local-dir/file

rdiff-backup host.net::/remote-dir/file local-dir/file

rdiff-backup restore --at now host.net::/remote-dir/file local-dir/file
----

The `--restore-as-of` (or `-r` for short) switch (`restore` action on the new CLI) tells rdiff-backup to restore instead of back up, and the `now` option indicates the current time.

But the main advantage of rdiff-backup is that it keeps version history.
This command restores `host.net::/remote-dir/file` as it was 10 days ago into a new location `/tmp/file`.

----
rdiff-backup -r 10D host.net::/remote-dir/file /tmp/file

rdiff-backup restore --at 10D host.net::/remote-dir/file /tmp/file
----

Other acceptable time strings include `5m4s` (5 minutes and 4 seconds) and `2002-03-05` (March 5th, 2002).
For more information, see the TIME FORMATS section of the manual page.

Finally, we can use rdiff-backup to restore directly from an increment file.
Increment files are stored in `host.net::/remote-dir/rdiff-backup-data/increments` and hold the previous versions of changed files.
If you specify one directly:

----
rdiff-backup host.net::/remote-dir/rdiff-backup-data/increments/file.2003-03-05T12:21:41-07:00.diff.gz local-dir/file

rdiff-backup restore host.net::/remote-dir/rdiff-backup-data/increments/file.2003-03-05T12:21:41-07:00.diff.gz local-dir/file
----

rdiff-backup will tell from the filename that it is an rdiff-backup increment file and thus enter restore mode.
Above the restored version is written to `local-dir/file`.

== Deleting older files

Although rdiff-backup tries to save space by only storing file differences, eventually space may run out in the destination directory.
rdiff-backup's `--remove-older-than` mode can be used to delete older increments.

This section assumes that rdiff-backup has been used in the past to back up to `host.net::/remote-dir`, but all commands would work locally too, if the hostname were omitted.

This commands deletes all information concerning file versions which have not been current for 2 weeks:

----
rdiff-backup --remove-older-than 2W host.net::/remote-dir

rdiff-backup remove increments --older-than 2W host.net::/remote-dir
----

NOTE: you might need to add the `--force` option if the selection leads to the removal of more than one increment at once.

Note that an existing file which hasn't changed for a year will still be preserved.
But a file which was deleted 15 days ago cannot be restored after this command is run.

As when restoring, there are a variety of ways to specify the time.
The `20B` below tells rdiff-backup to only preserve information from the last 20 rdiff-backup sessions.
(`nnB` syntax is only available in versions after 0.13.1.)

----
rdiff-backup --remove-older-than 20B host.net::/remote-dir

rdiff-backup remove increments --older-than 20B host.net::/remote-dir
----

== File selection with include/exclude options

Sometimes you don't want to back up all files.
The various `--include` and `--exclude` options can be used to select exactly which files to back up.
See the man page for a list of all the options and their definitions.

We have excluded `/proc`, `/tmp`, and `/mnt`.
`/proc` in particular should never be backed up.
Also, the source directory happens to be remote.

----
rdiff-backup --exclude /tmp --exclude /mnt --exclude /proc user@host.net::/ /backup/host.net

rdiff-backup backup --exclude /tmp --exclude /mnt --exclude /proc user@host.net::/ /backup/host.net
----

Multiple include and exclude options take precedence in the order they are given.
The following command would back up `/usr/local/bin` but not `/usr/bin`.

----
rdiff-backup --include /usr/local --exclude /usr / host.net::/backup

rdiff-backup backup --include /usr/local --exclude /usr / host.net::/backup
----

rdiff-backup uses rsync-like wildcards, where `+**+` matches any path and `+*+` matches any path without a `/` in it.
Thus this command:

----
rdiff-backup --include /usr/local --include /var --exclude '**' / /backup

rdiff-backup backup --include /usr/local --include /var --exclude '**' / /backup
----

backs up only the `/usr/local` and `/var` directories.
The single quotes `+''+` are not part of rdiff-backup and are only used because many shells will expand `+**+`.

Here is a more complicated example:

----
rdiff-backup --include '**txt' --exclude /usr/local/games --include /usr/local --exclude /usr --exclude /backup --exclude /proc / /backup

rdiff-backup backup --include '**txt' --exclude /usr/local/games --include /usr/local --exclude /usr --exclude /backup --exclude /proc / /backup
----

The above command will back up any file ending in `txt`, even `/usr/local/games/pong/scores.txt` because that include has highest precedence.
The contents of the directory `/usr/local/bin` will get backed up, but not `/usr/share` or `/usr/local/games/pong`.

rdiff-backup can also accept a list of files to be backed up.
If the file `include-list` contains these two lines:

----
/var
/usr/bin/gzip
----

Then this command:

----
rdiff-backup --include-filelist include-list --exclude '**' / /backup

rdiff-backup backup --include-filelist include-list --exclude '**' / /backup
----

would only back-up the files `/var`, `/usr`, `/usr/bin`, and `/usr/bin/gzip`, but not `/var/log` or `/usr/bin/gunzip`.
Note that this differs from the `--include` option, since `--include /var` would also match `/var/log`.

The same file list can contain both include and exclude files.
If we create a file called `include-list` that contains these lines:

----
**txt
- /usr/local/games
/usr/local
- /usr
- /backup
- /proc
----

Then the following command will do exactly the same thing as the complicated example above.

----
rdiff-backup --include-globbing-filelist include-list / /backup

rdiff-backup backup --include-globbing-filelist include-list / /backup
----

Above we have used `--include-globbing-filelist` instead of `--include-filelist` so that the lines would be interpreted as if they were specified on the command line.
Otherwise, for instance, `**txt` would be considered the name of a file, not a globbing string.

== Getting information about the backup directory

The following examples assume that you have run `rdiff-backup in-dir out-dir` in the past.

This command finds all new or old files which contain the string `frobniz`.

----
find out-dir -name '*frobniz*'
----

rdiff-backup doesn't obscure the names of files unless the file system doesn't support its length or certain characters, so often using traditional tools work well.

Either of these equivalent commands lists the times of the available versions of the file `out-dir/file`.
It may be useful if you need to restore an older version of `in-dir/file` but aren't sure which one.

----
rdiff-backup --list-increments out-dir/file
rdiff-backup -l out-dir/file

rdiff-backup list increments out-dir/file
----

The following command lists all the files under `out-dir/subdir` which has changed in the last 5 days.

----
rdiff-backup --list-changed-since 5D out-dir/subdir

rdiff-backup list files --changed-since 5D out-dir/subdir
----

This command lists all the files that were present in `out-dir/subdir` 5 days ago.
This includes files that have not changed recently as well as those that have been deleted in the last 5 days.

----
rdiff-backup --list-at-time 5D out-dir/subdir

rdiff-backup list files --at 5D out-dir/subdir
----

rdiff-backup writes one statistics file per session to the `out-dir/rdiff-backup-data` directory.
An average of the files can be displayed using the `--calculate-average` option and specifying the statistics files to use.

----
rdiff-backup --calculate-average out-dir/rdiff-backup-data/session_statistics*

rdiff-backup calculate --method average out-dir/rdiff-backup-data/session_statistics*
----

== Miscellaneous other commands

If you are having problems connecting to a remote host, the `--test-server` command may be useful.
This command simply verifies that there is a working rdiff-backup server on the remote side.

----
rdiff-backup --test-server hostname.net::/ignored

rdiff-backup test hostname.net::/somedir
----

IMPORTANT: starting with version 2.2, rdiff-backup also checks that it can access the given remote directory.