mirror of
https://github.com/borgbackup/borg.git
synced 2024-12-31 20:26:40 +00:00
Merge pull request #4434 from ThomasWaldmann/file-changed-warning
determine whether a file has changed while being backed up, fixes #1750
This commit is contained in:
commit
f20e6d751f
2 changed files with 17 additions and 1 deletions
|
@ -1226,9 +1226,22 @@ def process_file(self, *, path, parent_fd, name, st, cache, flags=flags_normal):
|
||||||
else:
|
else:
|
||||||
with backup_io('read'):
|
with backup_io('read'):
|
||||||
self.process_file_chunks(item, cache, self.stats, self.show_progress, backup_io_iter(self.chunker.chunkify(None, fd)))
|
self.process_file_chunks(item, cache, self.stats, self.show_progress, backup_io_iter(self.chunker.chunkify(None, fd)))
|
||||||
if not is_special_file:
|
if is_win32:
|
||||||
|
changed_while_backup = False # TODO
|
||||||
|
else:
|
||||||
|
with backup_io('fstat2'):
|
||||||
|
st2 = os.fstat(fd)
|
||||||
|
# special files:
|
||||||
|
# - fifos change naturally, because they are fed from the other side. no problem.
|
||||||
|
# - blk/chr devices don't change ctime anyway.
|
||||||
|
changed_while_backup = not is_special_file and st.st_ctime_ns != st2.st_ctime_ns
|
||||||
|
if changed_while_backup:
|
||||||
|
status = 'C' # regular file changed while we backed it up, might be inconsistent/corrupt!
|
||||||
|
if not is_special_file and not changed_while_backup:
|
||||||
# we must not memorize special files, because the contents of e.g. a
|
# we must not memorize special files, because the contents of e.g. a
|
||||||
# block or char device will change without its mtime/size/inode changing.
|
# block or char device will change without its mtime/size/inode changing.
|
||||||
|
# also, we must not memorize a potentially inconsistent/corrupt file that
|
||||||
|
# changed while we backed it up.
|
||||||
cache.memorize_file(path_hash, st, [c.id for c in item.chunks])
|
cache.memorize_file(path_hash, st, [c.id for c in item.chunks])
|
||||||
self.stats.nfiles += 1
|
self.stats.nfiles += 1
|
||||||
md = self.metadata_collector.stat_attrs(st, path, fd=fd)
|
md = self.metadata_collector.stat_attrs(st, path, fd=fd)
|
||||||
|
|
|
@ -695,6 +695,8 @@ def _process(self, *, path, parent_fd=None, name=None,
|
||||||
except (BackupOSError, BackupError) as e:
|
except (BackupOSError, BackupError) as e:
|
||||||
self.print_warning('%s: %s', path, e)
|
self.print_warning('%s: %s', path, e)
|
||||||
status = 'E'
|
status = 'E'
|
||||||
|
if status == 'C':
|
||||||
|
self.print_warning('%s: file changed while we backed it up', path)
|
||||||
# Status output
|
# Status output
|
||||||
if status is None:
|
if status is None:
|
||||||
if not dry_run:
|
if not dry_run:
|
||||||
|
@ -3106,6 +3108,7 @@ def define_archive_filters_group(subparser, *, sort_by=True, first_last=True):
|
||||||
- 'A' = regular file, added (see also :ref:`a_status_oddity` in the FAQ)
|
- 'A' = regular file, added (see also :ref:`a_status_oddity` in the FAQ)
|
||||||
- 'M' = regular file, modified
|
- 'M' = regular file, modified
|
||||||
- 'U' = regular file, unchanged
|
- 'U' = regular file, unchanged
|
||||||
|
- 'C' = regular file, it changed while we backed it up
|
||||||
- 'E' = regular file, an error happened while accessing/reading *this* file
|
- 'E' = regular file, an error happened while accessing/reading *this* file
|
||||||
|
|
||||||
A lowercase character means a file type other than a regular file,
|
A lowercase character means a file type other than a regular file,
|
||||||
|
|
Loading…
Reference in a new issue