Use rsync option -S
The filesystems may contains huge sparse files (for example the docker data file at path /var/lib/docker/devicemapper/devicemapper/data that is 100G big). These files causes rsync to fail if the target file-system is too small to copy them. The option --sparse tells rsync to turn sequences of nulls into sparse blocks. --sparse, -S Try to handle sparse files efficiently so they take up less space on the destination. If combined with --inplace the file created might not end up with sparse blocks with some combinations of kernel version and/or filesystem type. If --whole-file is in effect (e.g. for a local copy) then it will always work because rsync truncates the file prior to writing out the updated version. Note that versions of rsync older than 3.1.3 will reject the combination of --sparse and --inplace. This adds the rsync short option -S to let rsync handle sparse files. Fixes: 18:03:36 [6]: static CalamaresUtils::ProcessResult CalamaresUtils::System::runCommand(CalamaresUtils::System::RunLocation, const QStringList&, const QString&, const QString&, std::chrono::seconds) Running "env" ("sync") .. Finished. Exit code: 0 .. Target cmd: ("sync") output: rsync: [receiver] write failed on "/tmp/calamares-root-81qie5d1/var/lib/docker/devicemapper/devicemapper/data": No space left on device (28) rsync error: error in file IO (code 11) at receiver.c(378) [receiver=v3.2.3] Signed-off-by: Jeremy Whiting <jpwhiting@kde.org>
This commit is contained in:
parent
97da73b170
commit
194ebeba94
@ -176,7 +176,7 @@ def file_copy(source, entry, progress_cb):
|
|||||||
num_files_total_local = 0
|
num_files_total_local = 0
|
||||||
num_files_copied = 0 # Gets updated through rsync output
|
num_files_copied = 0 # Gets updated through rsync output
|
||||||
|
|
||||||
args = ['rsync', '-aHAXr', '--filter=-x trusted.overlay.*']
|
args = ['rsync', '-aHAXSr', '--filter=-x trusted.overlay.*']
|
||||||
args.extend(global_excludes())
|
args.extend(global_excludes())
|
||||||
if entry.excludeFile:
|
if entry.excludeFile:
|
||||||
args.extend(["--exclude-from=" + entry.excludeFile])
|
args.extend(["--exclude-from=" + entry.excludeFile])
|
||||||
|
Loading…
Reference in New Issue
Block a user