replicator: User listing returned failure
Alexey
alukardd at alukardd.org
Mon May 7 23:33:48 EEST 2018
Hello.
I've tried to configure TCP replication to slave server. But I got some
errors...
mx1:~# dovecot --version
2.2.27 (c0f36b0)
From dovecot.log:
May 07 19:27:41 auth-worker(34348): Warning: mysql: Query failed,
retrying: Unknown column 'username' in 'field list'
May 07 19:27:41 auth-worker(34348): Debug: sql(*): SELECT username,
domain FROM users
May 07 19:27:41 auth-worker(34348): Error: sql: Iterate query failed:
Unknown column 'username' in 'field list' (using built-in default
iterate_query: SELECT username, domain FROM users)
May 07 19:27:41 auth-worker(34348): Debug: sql(*): SELECT id AS
username, domain FROM users
May 07 19:27:41 replicator: Error: User listing returned failure
May 07 19:27:41 replicator: Error: listing users failed, can't replicate
existing data
mx1:~# doveadm replicator status
Queued 'sync' requests 0
Queued 'high' requests 0
Queued 'low' requests 0
Queued 'failed' requests 0
Queued 'full resync' requests 0
Waiting 'failed' requests 2
Total number of known users 2
mx1:~# doveadm replicator status '*'
username
priority fast sync full sync success sync failed
abuse at example.com
none 00:03:01 01:06:36 - y
admin at exmaple.com
none 00:03:41 01:31:49 - y
From slave:
mx2:~# cat /etc/dovecot/conf.d/90-replication.conf
# use tcp:hostname as the dsync target
plugin {
mail_replica = tcp:mx1 # use doveadm_port
}
As I can see nothing happens automatically.
But mx2:~# doveadm -D sync -u abuse at example.com -d -N -l 30 -U
successfully executed and getting mails from mx1.
dovecot-sql.conf.ext:
driver = mysql
connect = host=localhost dbname=vmail user=sqlmail
password=sqL_hidden033|TGPAS
default_pass_scheme = SHA512-CRYPT
password_query = SELECT id AS username, password, domain FROM users
WHERE id = '%n' AND domain = '%d' AND active = 'Y'
user_query = SELECT id AS username, uid, gid, home, concat('*:storage=',
quota, 'M' ) as quota_rule FROM users WHERE id = '%n' AND domain = '%d'
iterate_query = SELECT id AS username, domain FROM users
Regards,
Alexey
mx1:~# dovecot -n
# 2.2.27 (c0f36b0): /etc/dovecot/dovecot.conf
# Pigeonhole version 0.4.16 (fed8554)
# OS: Linux 4.9.0-6-amd64 x86_64 Debian 9.4
auth_master_user_separator = *
auth_verbose = yes
auth_verbose_passwords = sha1
default_vsz_limit = 512 M
doveadm_password = # hidden, use -P to show it
doveadm_port = 994
hostname = mx1.example.com
imap_client_workarounds = delay-newmail tb-extra-mailbox-sep
tb-lsub-flags
imap_idle_notify_interval = 12 mins
lda_mailbox_autocreate = yes
lda_mailbox_autosubscribe = yes
lmtp_save_to_detail_mailbox = yes
log_path = /var/log/dovecot/dovecot.log
mail_access_groups = mail
mail_location = mdbox:~/mdbox:UTF-8
mail_plugins = " notify replication"
managesieve_notify_capability = mailto
managesieve_sieve_capability = fileinto reject envelope
encoded-character vacation subaddress comparator-i;ascii-numeric
relational regex imap4flags copy include variables body enotify
environment mailbox date index ihave duplicate mime foreverypart
extracttext
namespace inbox {
inbox = yes
location =
mailbox Drafts {
auto = subscribe
special_use = \Drafts
}
mailbox Junk {
auto = subscribe
special_use = \Junk
}
mailbox Sent {
auto = subscribe
special_use = \Sent
}
mailbox Trash {
auto = subscribe
special_use = \Trash
}
prefix =
}
passdb {
args = /etc/dovecot/dovecot-sql-master.conf.ext
driver = sql
master = yes
pass = yes
}
passdb {
args = /etc/dovecot/dovecot-sql.conf.ext
driver = sql
}
plugin {
quota = dict:User quota::proxy::quota
quota_rule = *:storage=100G
quota_rule2 = Trash:storage=+10G
quota_warning = storage=95%% quota-warning 95 %u
quota_warning2 = storage=80%% quota-warning 80 %u
sieve_before = /srv/vmail/dovecot_global_filter.sieve
sieve_dir = ~/sieve
sieve_global_extensions = +vnd.dovecot.duplicate
}
postmaster_address = postmaster at example.com
protocols = " imap lmtp sieve"
service aggregator {
fifo_listener replication-notify-fifo {
group = mail
mode = 0660
user = dovecot
}
unix_listener replication-notify {
group = mail
mode = 0660
user = dovecot
}
}
service auth {
unix_listener auth-client {
group = mail
mode = 0660
}
unix_listener auth-userdb {
group = mail
}
}
service dict {
unix_listener dict {
group = mail
mode = 0660
user = dovecot
}
}
service doveadm {
inet_listener {
port = 994
}
}
service lmtp {
executable = lmtp -L
unix_listener lmtp {
group = mail
mode = 0660
}
}
service managesieve-login {
inet_listener sieve {
port = 4190
}
}
service quota-warning {
executable = script /usr/local/bin/quota-warning.sh
unix_listener quota-warning {
user = mail
}
user = dovecot
}
service replicator {
process_min_avail = 1
unix_listener replicator-doveadm {
group = mail
mode = 0660
user = dovecot
}
}
ssl = required
ssl_cert = </etc/ssl/example.com/fullchain-combo.crt
ssl_cipher_list =
ALL:HIGH:!SSLv2:!SSLv3:!MEDIUM:!LOW:!EXP:!RC4:!MD5:!aNULL:@STRENGTH
ssl_key = # hidden, use -P to show it
userdb {
args = /etc/dovecot/dovecot-sql-master.conf.ext
driver = sql
}
userdb {
args = /etc/dovecot/dovecot-sql.conf.ext
driver = sql
}
protocol lmtp {
log_path = /var/log/dovecot/lmtp.log
mail_plugins = " notify replication sieve"
}
protocol lda {
log_path = /var/log/dovecot/lda.log
mail_plugins = " notify replication sieve"
}
protocol imap {
mail_plugins = " notify replication"
}
More information about the dovecot
mailing list