LDAP coruption после обновления
Я обновил openldap с openldap-2.4.39-8.el6.x86_64 до 2.4.40-12.el6.x86_64 и после перезапуска сервера я получаю следующую ошибку. Я пытаюсь решить, как восстановить, поскольку у меня нет резервной копии.
586d0afc <<< dnNormalize: <cn=write>
586d0afc backend_startup_one: starting "dc=custsvc,dc=mycompany"
586d0afc bdb_db_open: "dc=custsvc,dc=mycompany"
586d0afc bdb_db_open: database "dc=custsvc,dc=mycompany": dbenv_open(/var/lib/ldap).
586d0afc bdb(dc=custsvc,dc=mycompany): file id2entry.bdb has LSN 1/720219, past end of log at 1/600
586d0afc bdb(dc=custsvc,dc=mycompany): Commonly caused by moving a database from one database environment
586d0afc bdb(dc=custsvc,dc=mycompany): to another without clearing the database LSNs, or by removing all of
586d0afc bdb(dc=custsvc,dc=mycompany): the log files from a database environment
586d0afc bdb(dc=custsvc,dc=mycompany): /var/lib/ldap/id2entry.bdb: unexpected file type or format
586d0afc bdb_db_open: database "dc=custsvc,dc=mycompany": db_open(/var/lib/ldap/id2entry.bdb) failed: Invalid argument (22).
586d0afc ====> bdb_cache_release_all
586d0afc backend_startup_one (type=bdb, suffix="dc=custsvc,dc=mycompany"): bi_db_open failed! (22)
586d0afc slapd shutdown: initiated
586d0afc ====> bdb_cache_release_all
586d0afc bdb_db_close: database "dc=custsvc,dc=mycompany": alock_close failed
586d0afc slapd destroy: freeing system resources.
586d0afc slapd stopped.
1 ответ
Так что после просмотра интернета и не найдя решения, которое работало, и единственный рекомендуемый метод оказался db_recover -v -h /var/lib/ldap/
который не работал, но я заметил, что это увеличило контрольную точку восстановления.
[root@lddev-build-par01 ~]# db_recover -v -h /var/lib/ldap/
Finding last valid log LSN: file: 1 offset 1632
Recovery complete at Wed Jan 4 14:52:26 2017
Maximum transaction ID 0 Recovery checkpoint [1][1632]
[root@lddev-build-par01 ~]# db_recover -v -h /var/lib/ldap/
Finding last valid log LSN: file: 1 offset 1724
Recovery complete at Wed Jan 4 14:52:26 2017
Maximum transaction ID 0 Recovery checkpoint [1][1724]
Поэтому, убедившись, что у меня есть резервная копия моих нерабочих данных, я просто запускал эту команду много раз, пока контрольная точка восстановления не оказалась выше, чем там, где, как полагал файл BDB, была проблема. Я не ожидал, что это сработает.
while true; do db_recover -v -h /var/lib/ldap/; done
Но это сделал:-)
Я не хотел бы гарантировать, что потеря данных не произошла, но поскольку это была среда разработки, это еще не конец света, и тестовый набор скоро обнаружит какие-либо проблемы. Надеюсь, это кому-нибудь поможет.