How-to: clean up the translog from a certain point in time

How to clean up the translog from a certain point in time

Environment

  1. UCS 4.4

Note 1: If you only want to reduce the database and you want to keep the last x entries check this article.
Note 2: I assume to clean everything in transog before 1st of January 2021.
Note 3: You must ensure that all servers (backups and slaves) are replicated at least to the TID you want to reduce to!

Get TID of the certain point in time and clean the translog database.

Step 1: Get the last TID of the timewindow, we want to delete out of the translog

root@dc0:~# ldapsearch -x -H ldapi:// -LLL -b cn=translog '(&(reqStart<=20210101000000Z)(reqStart>=20201201000000Z))' reqSession |tail -n 2
reqSession: 122933

Please adjust the reqStart timestamps to your needs!

My last TID in 2020 was 122933

Step 2 Check the last entry to delete

root@dc0:~ # ldapsearch -x -H ldapi:// -LLL -b reqSession=122933,cn=translog createTimestamp
dn: reqSession=122933,cn=translog
createTimestamp: 20201225203654Z

Step 3 Check the first entry to keep

root@dc0:~ # ldapsearch -x -H ldapi:// -LLL -b reqSession=122934,cn=translog createTimestamp
dn: reqSession=122934,cn=translog
createTimestamp: 20210104000805Z

Step 4 Clean up

root@dc0:~ # /usr/share/univention-directory-notifier/univention-translog -v prune 122933
2021-11-15 08:43:30,238:INFO:Index of size 1546064 contains 171784 entries
2021-11-15 08:43:30,245:INFO:Purging/keeping 1..122933..171783
2021-11-15 08:43:30,648:INFO:Removing /var/lib/univention-ldap/notify/transaction.index ...
2021-11-15 08:43:30,674:INFO:INFO:Deleted reqSession=1,cn=translog
2021-11-15 08:43:30,674:INFO:Deleted reqSession=2,cn=translog
...
2021-11-15 08:47:36,335:INFO:Deleted reqSession=122931,cn=translog
2021-11-15 08:47:36,335:INFO:Deleted reqSession=122932,cn=translog

Step 5 Clean up free pages

After that the free pages must be cleaned up. But technically that’s not required and the necessity should be considered in relation to downtime. Anyway these would be the steps:

root@ucs:~# mkdir /var/lib/univention-ldap/translog-new
root@ucs:~# systemctl stop univention-directory-notifier.service
root@ucs:~# systemctl stop slapd.service
root@ucs:~# mdb_copy -c /var/lib/univention-ldap/translog /var/lib/univention-ldap/translog-new
root@ucs:~# mv /var/lib/univention-ldap/translog /var/lib/univention-ldap/translog-old
root@ucs:~# mv /var/lib/univention-ldap/translog-new /var/lib/univention-ldap/translog
root@ucs:~# systemctl start slapd.service
root@ucs:~# systemctl start univention-directory-notifier.service

Recheck with nagios the space is freed
/usr/lib/nagios/plugins/check_univention_slapd_mdb_maxsize


(Optional) Step 6: Notifier indexing slows rapidly down

If /usr/share/univention-directory-notifier/univention-translog stat shows an
AssertionError this indicates that the transaction.index is corrupt or uses wrong data.

Traceback (most recent call last):
   File "/usr/share/univention-directory-notifier/univention-translog",
 line 1472, in <module>
     exit(main())
   File "/usr/share/univention-directory-notifier/univention-translog", line 421, in main
     return opt.func(opt) or 0
   File "/usr/share/univention-directory-notifier/univention-translog",
 line 553, in show_stat
     with Index(opt.translog_file) as index,
 Translog(opt.translog_file, index) as
 translog:
   File "/usr/share/univention-directory-notifier/univention-translog",
 line 148, in __enter__
     assert reminder == 0, reminder
 AssertionError: 7

UCS5 Bugfix 54797

UCS4 Bugfix 55863

You have to do an reindex from the notifier. During this time, replication is not working at all and this could take some time in large environments.

/usr/share/univention-directory-notifier/univention-translog reindex

see also:

Mastodon