Резервное копирование Dovecot doveadm иногда завершается ошибкой 65 — как ее устранить

Резервное копирование Dovecot doveadm иногда завершается ошибкой 65 — как ее устранить

Я пытаюсь настроить резервное копирование писем dovecot между 2 серверами. Команда, выполняющая тяжелую работу, следующая:

 doveadm -D backup -R -u [email protected] ssh MAINSERVER.IP doveadm dsync-server -u [email protected]

У большинства пользователей это работает нормально, но у нескольких пользователей я получаю ошибку 65 или ошибку 75. (В скрипте говорится, что удаленная команда вернула ошибку 75...), но когда я помещаю это в скрипт, код возврата — 65.

Вывод dovecot для неудавшейся учетной записи выглядит следующим образом:

Debug: Loading modules from directory: /usr/lib/dovecot/modules/doveadm
Debug: Skipping module doveadm_acl_plugin, because dlopen() failed: /usr/lib/dovecot/modules/doveadm/lib10_doveadm_acl_plugin.so: undefined symbol: acl_user_module (this is usually intentional, so just ignore this message)
Debug: Skipping module doveadm_expire_plugin, because dlopen() failed: /usr/lib/dovecot/modules/doveadm/lib10_doveadm_expire_plugin.so: undefined symbol: expire_set_deinit (this is usually intentional, so just ignore this message)
Debug: Skipping module doveadm_quota_plugin, because dlopen() failed: /usr/lib/dovecot/modules/doveadm/lib10_doveadm_quota_plugin.so: undefined symbol: quota_user_module (this is usually intentional, so just ignore this message)
Debug: Module loaded: /usr/lib/dovecot/modules/doveadm/lib10_doveadm_sieve_plugin.so
Debug: Skipping module doveadm_fts_plugin, because dlopen() failed: /usr/lib/dovecot/modules/doveadm/lib20_doveadm_fts_plugin.so: undefined symbol: fts_user_get_language_list (this is usually intentional, so just ignore this message)
Debug: Skipping module doveadm_mail_crypt_plugin, because dlopen() failed: /usr/lib/dovecot/modules/doveadm/libdoveadm_mail_crypt_plugin.so: undefined symbol: mail_crypt_box_get_pvt_digests (this is usually intentional, so just ignore this message)
doveadm([email protected]): Debug: Effective uid=999, gid=999, home=/data/mail/[email protected]
doveadm([email protected]): Debug: maildir++: root=/data/mail/[email protected]/Maildir, index=, indexpvt=, control=, inbox=/data/mail/[email protected]/Maildir, alt=
doveadm([email protected]): Debug: Namespace : Using permissions from /data/mail/[email protected]/Maildir: mode=0700 gid=default
dsync-local([email protected]): Debug: brain M: Local mailbox tree: INBOX guid=58eedf276bc33864df08000079bc729c uid_validity=1681441643 uid_next=2 subs=no last_change=0 last_subs=0
dsync-local([email protected]): Debug: brain M: Remote mailbox tree: INBOX guid=58eedf276bc33864df08000079bc729c uid_validity=1396487587 uid_next=60912 subs=no last_change=0 last_subs=0
dsync-local([email protected]): Debug: brain M: Remote mailbox tree: Deleted Messages guid=c803c2075f1e625874120000b8a5d860 uid_validity=1396487588 uid_next=36883 subs=yes last_change=0 last_subs=1482825311
dsync-local([email protected]): Debug: brain M: Remote mailbox tree: Sent Messages guid=55567b0e54b57d58770d0000b8a5d860 uid_validity=1396487589 uid_next=345 subs=yes last_change=0 last_subs=1484633428
dsync-local([email protected]): Debug: brain M: Remote mailbox tree: Drafts guid=8e1b6a01ab197e602d700000b8a5d860 uid_validity=1396487591 uid_next=1 subs=yes last_change=0 last_subs=1618876837
dsync-local([email protected]): Debug: brain M: Remote mailbox tree: Notes guid=da8ed0191098355c672d0000b8a5d860 uid_validity=1396487590 uid_next=1 subs=yes last_change=0 last_subs=1547016208
dsync-local([email protected]): Debug: brain M: Mailbox Deleted Messages: local=00000000000000000000000000000000/0/0, remote=c803c2075f1e625874120000b8a5d860/0/1: mailbox not selectable yet
dsync-local([email protected]): Debug: brain M: Mailbox Drafts: local=00000000000000000000000000000000/0/0, remote=8e1b6a01ab197e602d700000b8a5d860/0/1: mailbox not selectable yet
dsync-local([email protected]): Debug: brain M: Mailbox INBOX: local=58eedf276bc33864df08000079bc729c/0/1, remote=58eedf276bc33864df08000079bc729c/0/1: Mailboxes are equal
dsync-local([email protected]): Debug: brain M: Mailbox Notes: local=00000000000000000000000000000000/0/0, remote=da8ed0191098355c672d0000b8a5d860/0/1: mailbox not selectable yet
dsync-local([email protected]): Debug: brain M: Mailbox Sent Messages: local=00000000000000000000000000000000/0/0, remote=55567b0e54b57d58770d0000b8a5d860/0/1: mailbox not selectable yet
dsync-local([email protected]): Debug: brain M: Deleting mailbox 'INBOX' (GUID 58eedf276bc33864df08000079bc729c): UIDVALIDITY changed (1396487587 -> 1681441643)
dsync-local([email protected]): Debug: doveadm-sieve: Iterating Sieve mailbox attributes
dsync-local([email protected]): Debug: sieve: Pigeonhole version 0.4.21 (92477967) initializing
dsync-local([email protected]): Debug: sieve: include: sieve_global is not set; it is currently not possible to include `:global' scripts.
dsync-local([email protected]): Debug: sieve: file storage: Using active Sieve script path: /data/mail/[email protected]/.dovecot.sieve
dsync-local([email protected]): Debug: sieve: file storage: Using script storage path: /data/mail/[email protected]/sieve
dsync-local([email protected]): Debug: sieve: file storage: Using permissions from /data/mail/[email protected]/sieve: mode=0700 gid=-1
dsync-local([email protected]): Debug: sieve: file storage: Relative path to sieve storage in active link: sieve/
dsync-local([email protected]): Debug: sieve: file storage: sync: Synchronization active
dsync-local([email protected]): Error: Mailbox INBOX sync: mailbox_delete failed: INBOX can't be deleted.
dsync-local([email protected]): Error: Remote command returned error 75: ssh 60.234.77.233 doveadm dsync-server -u [email protected] dsync-server

Несмотря на сообщение «Удаленная команда вернула ошибку 75», я знаю, что если я удалю почтовый ящик на локальном сервере и снова выполню команду, она будет повторно синхронизирована, но это означает удаление почтового ящика клиента на локальном сервере, чего я бы предпочел не делать, так как они могут стать довольно большими, а пропускная способность между сайтами немного ограничена.

Я также считаю, что если я выполняю синхронизацию вместо резервного копирования (чего я предпочитаю не делать, поскольку я новичок в doveadm и не хочу подвергать оригинал риску), то ошибки не возникнет.

Я полагаю, что проблема, скорее всего, связана с тем фактом, что в первых двух строках говорится о INBOX, но я не понимаю, как это произошло (я только сделал синхронизацию почтового ящика, возможно, прерывая ее, но ничего больше), и это тоже немного беспокоит.

Я использую формат MAILDIR и подозреваю, что часть проблемы связана с MAILDIR и невозможностью удалить папку «Входящие», но я не понимаю, почему она пытается удалить папку «Входящие», и я даже не знаю, что имеется в виду под папкой «Входящие», поскольку я не могу найти папку с названием «/ВХОДЯЩИЕ" или "/.INBOX" или аналогичный на сервере или в резервной копии. "Maildir/cur" и "Maildir/new" оба существуют (и пусты на клиенте). В Maildir/new есть электронные письма на сервере, но он пуст на клиенте.

Сначала я попробовал это сделать на своем сервере на Ubuntu 18.04, Dovecot 1:2.2.33.2-1ubuntu4.8. Затем я обновил ТОЛЬКО резервную копию, с которой я извлекаю данные, чтобы запустить Ubuntu 20.04 с Dovecot 2.3.7.2 — та же проблема.

Это известная ошибка в Dovecot? Есть ли способ решить ее, не удаляя почтовые ящики?

ОБНОВЛЕНИЯ

doveconf mail_location установлен на mail_location = maildir:/data/mail/%u/Maildir (что похоже на то, что я ожидал). Я не смог найти никакой информации о конфигурации со словом "namespace"

Когда я делаю

 doveadm mailbox status -u [email protected] all INBOX 

Я получаю разные результаты на клиенте и сервере. На почтовом сервере я получаю

 INBOX messages=524 recent=0 uidnext=60920 uidvalidity=1396487587 unseen=2 highestmodseq=59948 vsize=77692641 guid=58eedf276bc33864df08000079bc729c firstsaved=1680336216

На резервной копии я получаю

  INBOX messages=0 recent=0 uidnext=2 uidvalidity=1681441643 unseen=0 highestmodseq=3 vsize=0 guid=58eedf276bc33864df08000079bc729c firstsaved=18446744073709551615

В каждом из проблемных почтовых каталогов «MAILDIR/cur -s пуст в резервной версии, в то время как в версии на сервере есть данные.

Когда я попытался скопировать почтовый ящик «cur» с почтового сервера на резервную копию, а затем запустить «doveadm mailbox status -u[email protected]все ВХОДЯЩИЕ» количество сообщений вернулось к 524, но как только я попытался сделать резервную копию ящика, ошибка появилась снова, и в папке ВХОДЯЩИЕ на резервном сервере оказалось 0 сообщений.

Поэкспериментируйте с командой "doveadm force-resync -u[email protected]INBOX" на почтовом сервере и резервное копирование (после повторного заполнения Maildir/cur на резервной копии через scp) не помогло.

Связанный контент