mirror of
https://github.com/borgbackup/borg.git
synced 2025-01-22 15:28:57 +00:00
Merge pull request #6022 from pgerber/recover
Speed up search for next valid object in segment in --repair mode
This commit is contained in:
commit
9dfdd9f06a
1 changed files with 15 additions and 4 deletions
|
@ -38,6 +38,15 @@
|
|||
TAG_DELETE = 1
|
||||
TAG_COMMIT = 2
|
||||
|
||||
# Highest ID usable as TAG_* value
|
||||
#
|
||||
# Code may expect not to find any tags exceeding this value. In particular,
|
||||
# in order to speed up `borg check --repair`, any tag greater than MAX_TAG_ID
|
||||
# is assumed to be corrupted. When increasing this value, in order to add more
|
||||
# tags, keep in mind that old versions of Borg accessing a new repository
|
||||
# may not be able to handle the new tags.
|
||||
MAX_TAG_ID = 15
|
||||
|
||||
FreeSpace = partial(defaultdict, int)
|
||||
|
||||
|
||||
|
@ -1518,10 +1527,8 @@ def recover_segment(self, segment, filename):
|
|||
dst_fd.write(MAGIC)
|
||||
while len(d) >= self.header_fmt.size:
|
||||
crc, size, tag = self.header_fmt.unpack(d[:self.header_fmt.size])
|
||||
if size < self.header_fmt.size or size > len(d):
|
||||
d = d[1:]
|
||||
continue
|
||||
if crc32(d[4:size]) & 0xffffffff != crc:
|
||||
if size > MAX_OBJECT_SIZE or tag > MAX_TAG_ID or size < self.header_fmt.size \
|
||||
or size > len(d) or crc32(d[4:size]) & 0xffffffff != crc:
|
||||
d = d[1:]
|
||||
continue
|
||||
dst_fd.write(d[:size])
|
||||
|
@ -1550,6 +1557,10 @@ def read(self, segment, offset, id, read_data=True):
|
|||
|
||||
def _read(self, fd, fmt, header, segment, offset, acceptable_tags, read_data=True):
|
||||
# some code shared by read() and iter_objects()
|
||||
|
||||
# See comment on MAX_TAG_ID for details
|
||||
assert max(acceptable_tags) <= MAX_TAG_ID, 'Exceeding MAX_TAG_ID will break backwards compatibility'
|
||||
|
||||
try:
|
||||
hdr_tuple = fmt.unpack(header)
|
||||
except struct.error as err:
|
||||
|
|
Loading…
Reference in a new issue