1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2025-01-03 05:35:58 +00:00

compact: remove --cleanup-commits

this was a one-time fix only needed for borg 1.2.

users are expected to use borg 1.2 to cleanup the commits.
This commit is contained in:
Thomas Waldmann 2022-06-26 00:07:07 +02:00
parent 162035da91
commit 3fbb297fd7
3 changed files with 4 additions and 19 deletions

View file

@ -2093,7 +2093,7 @@ def do_compact(self, args, repository):
data = repository.get(Manifest.MANIFEST_ID) data = repository.get(Manifest.MANIFEST_ID)
repository.put(Manifest.MANIFEST_ID, data) repository.put(Manifest.MANIFEST_ID, data)
threshold = args.threshold / 100 threshold = args.threshold / 100
repository.commit(compact=True, threshold=threshold, cleanup_commits=args.cleanup_commits) repository.commit(compact=True, threshold=threshold)
return EXIT_SUCCESS return EXIT_SUCCESS
@with_repository(exclusive=True, manifest=False) @with_repository(exclusive=True, manifest=False)
@ -3536,11 +3536,6 @@ def define_borg_mount(parser):
given by the ``--threshold`` option. If omitted, a threshold of 10% is used. given by the ``--threshold`` option. If omitted, a threshold of 10% is used.
When using ``--verbose``, borg will output an estimate of the freed space. When using ``--verbose``, borg will output an estimate of the freed space.
After upgrading borg (server) to 1.2+, you can use ``borg compact --cleanup-commits``
to clean up the numerous 17byte commit-only segments that borg 1.1 did not clean up
due to a bug. It is enough to do that once per repository. After cleaning up the
commits, borg will also do a normal compaction.
See :ref:`separate_compaction` in Additional Notes for more details. See :ref:`separate_compaction` in Additional Notes for more details.
""") """)
subparser = subparsers.add_parser('compact', parents=[common_parser], add_help=False, subparser = subparsers.add_parser('compact', parents=[common_parser], add_help=False,
@ -3549,8 +3544,6 @@ def define_borg_mount(parser):
formatter_class=argparse.RawDescriptionHelpFormatter, formatter_class=argparse.RawDescriptionHelpFormatter,
help='compact segment files / free space in repo') help='compact segment files / free space in repo')
subparser.set_defaults(func=self.do_compact) subparser.set_defaults(func=self.do_compact)
subparser.add_argument('--cleanup-commits', dest='cleanup_commits', action='store_true',
help='cleanup commit-only 17-byte segment files')
subparser.add_argument('--threshold', metavar='PERCENT', dest='threshold', subparser.add_argument('--threshold', metavar='PERCENT', dest='threshold',
type=int, default=10, type=int, default=10,
help='set minimum threshold for saved space in PERCENT (Default: 10)') help='set minimum threshold for saved space in PERCENT (Default: 10)')

View file

@ -905,9 +905,8 @@ def check(self, repair=False, save_space=False, max_duration=0):
@api(since=parse_version('1.0.0'), @api(since=parse_version('1.0.0'),
compact={'since': parse_version('1.2.0a0'), 'previously': True, 'dontcare': True}, compact={'since': parse_version('1.2.0a0'), 'previously': True, 'dontcare': True},
threshold={'since': parse_version('1.2.0a8'), 'previously': 0.1, 'dontcare': True}, threshold={'since': parse_version('1.2.0a8'), 'previously': 0.1, 'dontcare': True})
cleanup_commits={'since': parse_version('1.2.0a0'), 'previously': False, 'dontcare': True}) def commit(self, save_space=False, compact=True, threshold=0.1):
def commit(self, save_space=False, compact=True, threshold=0.1, cleanup_commits=False):
"""actual remoting is done via self.call in the @api decorator""" """actual remoting is done via self.call in the @api decorator"""
@api(since=parse_version('1.0.0')) @api(since=parse_version('1.0.0'))

View file

@ -495,7 +495,7 @@ def close(self):
self.lock.release() self.lock.release()
self.lock = None self.lock = None
def commit(self, save_space=False, compact=True, threshold=0.1, cleanup_commits=False): def commit(self, save_space=False, compact=True, threshold=0.1):
"""Commit transaction """Commit transaction
""" """
# save_space is not used anymore, but stays for RPC/API compatibility. # save_space is not used anymore, but stays for RPC/API compatibility.
@ -509,13 +509,6 @@ def commit(self, save_space=False, compact=True, threshold=0.1, cleanup_commits=
self.segments.setdefault(segment, 0) self.segments.setdefault(segment, 0)
self.compact[segment] += LoggedIO.header_fmt.size self.compact[segment] += LoggedIO.header_fmt.size
if compact and not self.append_only: if compact and not self.append_only:
if cleanup_commits:
# due to bug #2850, there might be a lot of commit-only segment files.
# this is for a one-time cleanup of these 17byte files.
for segment, filename in self.io.segment_iterator():
if os.path.getsize(filename) == 17:
self.segments[segment] = 0
self.compact[segment] = LoggedIO.header_fmt.size
self.compact_segments(threshold) self.compact_segments(threshold)
self.write_index() self.write_index()
self.rollback() self.rollback()