My Dsync isn't replicating 'EXPUNGE' IMAP command

Listas@Adminlinux listas at adminlinux.com.br
Tue Sep 9 18:56:06 UTC 2014


Hi!

I have two Dovecot-2.2.13 servers with Dsync Replication: server1 and 
server2.

When I execute 'EXPUNGE' on server1 side, the messages with FLAG 
\Deleted are expunged only on server1. The message is still present in 
Server2.

Could someone give me a hint reason for this ?
Thanks in advance!
--
Thiago Henrique

======================================================================
How I reproduce:

== ON SERVER1 ==

Client:         $ telnet <IP server1> 143
		Trying <IP server1>...
		Connected to <IP server1>.
		Escape character is '^]'.
Server:		* OK [CAPABILITY IMAP4rev1 LITERAL+ SASL-IR LOGIN-REFERRALS ID 
ENABLE IDLE AUTH=PLAIN AUTH=LOGIN] MAILBOX1 IMAP/POP3 server

Client:		AUTH LOGIN <user> <pass>
Server:		AUTH OK [CAPABILITY IMAP4rev1 LITERAL+ SASL-IR LOGIN-REFERRALS 
ID ENABLE IDLE SORT SORT=DISPLAY THREAD=REFERENCES THREAD=REFS 
THREAD=ORDEREDSUBJECT MULTIAPPEND URL-PARTIAL CATENATE UNSELECT CHILDREN 
NAMESPACE UIDPLUS LIST-EXTENDED I18NLEVEL=1 CONDSTORE QRESYNC ESEARCH 
ESORT SEARCHRES WITHIN CONTEXT=SEARCH LIST-STATUS SPECIAL-USE BINARY 
MOVE QUOTA] Logged in

Client:		A002 SELECT "INBOX"
Server:		* FLAGS (\Answered \Flagged \Deleted \Seen \Draft nonjunk)
		* OK [PERMANENTFLAGS (\Answered \Flagged \Deleted \Seen \Draft nonjunk 
\*)] Flags permitted.
		* 2 EXISTS
		* 0 RECENT
		* OK [UNSEEN 1] First unseen.
		* OK [UIDVALIDITY 1410284221] UIDs valid
		* OK [UIDNEXT 16] Predicted next UID
		* OK [HIGHESTMODSEQ 56] Highest
		A002 OK [READ-WRITE] Select completed (0.000 secs).

Client:		A003 FETCH 1:* (UID FLAGS)
Server:		* 1 FETCH (UID 13 FLAGS (nonjunk))
		* 2 FETCH (UID 15 FLAGS (nonjunk))
		A003 OK Fetch completed.

Client:		A005 STORE 1 +FLAGS \Deleted
Server:		* 1 FETCH (FLAGS (\Deleted nonjunk))
		A005 OK Store completed.

Client:		A003 FETCH 1:* (UID FLAGS)
Server:		* 1 FETCH (UID 13 FLAGS (\Deleted nonjunk))
		* 2 FETCH (UID 15 FLAGS (nonjunk))
		A003 OK Fetch completed.

Client:		A006 EXPUNGE
Server:		* 1 EXPUNGE
		A006 OK Expunge completed.

Client:		A007 FETCH 1:* (UID FLAGS)
Server:		* 1 FETCH (UID 15 FLAGS (nonjunk))
		A007 OK Fetch completed.

Client:		A008 LOGOUT
Server:		* BYE Logging out
		A008 OK Logout completed.
		Connection closed by foreign host.

== ON SERVER2 ==

Client:		$ telnet <IP server2> 143
		Trying <IP server2>...
		Connected to <IP server2>.
		Escape character is '^]'.
Server:		* OK [CAPABILITY IMAP4rev1 LITERAL+ SASL-IR LOGIN-REFERRALS ID 
ENABLE IDLE AUTH=PLAIN AUTH=LOGIN] MAILBOX2 IMAP/POP3 server

Client:		AUTH LOGIN <user> <pass>
Server:		AUTH OK [CAPABILITY IMAP4rev1 LITERAL+ SASL-IR LOGIN-REFERRALS 
ID ENABLE IDLE SORT SORT=DISPLAY THREAD=REFERENCES THREAD=REFS 
THREAD=ORDEREDSUBJECT MULTIAPPEND URL-PARTIAL CATENATE UNSELECT CHILDREN 
NAMESPACE UIDPLUS LIST-EXTENDED I18NLEVEL=1 CONDSTORE QRESYNC ESEARCH 
ESORT SEARCHRES WITHIN CONTEXT=SEARCH LIST-STATUS SPECIAL-USE BINARY 
MOVE QUOTA] Logged in

Client:		A002 SELECT "INBOX"
Server:		* FLAGS (\Answered \Flagged \Deleted \Seen \Draft nonjunk)
		* OK [PERMANENTFLAGS (\Answered \Flagged \Deleted \Seen \Draft nonjunk 
\*)] Flags permitted.
		* 2 EXISTS
		* 0 RECENT
		* OK [UNSEEN 1] First unseen.
		* OK [UIDVALIDITY 1410284221] UIDs valid
		* OK [UIDNEXT 17] Predicted next UID
		* OK [HIGHESTMODSEQ 61] Highest
		A002 OK [READ-WRITE] Select completed (0.000 secs).

Client:		A003 FETCH 1:* (UID FLAGS)
Server:		* 1 FETCH (UID 13 FLAGS (\Deleted nonjunk))
		* 2 FETCH (UID 15 FLAGS (nonjunk))
		A003 OK Fetch completed.

Client:		A008 LOGOUT
Server:		* BYE Logging out
		A008 OK Logout completed.
		Connection closed by foreign host.


= My settings =

* My settins age identical on both server1 and server2, except by 
'listen', 'address' and 'mail_replica' directives.

# doveconf -n
# 2.2.13 (6bb26098a45c): /etc/dovecot/dovecot.conf
# OS: Linux 3.13.0-30-generic x86_64 Ubuntu 14.04.1 LTS
auth_master_user_separator = *
auth_mechanisms = plain login
auth_username_chars = 
abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890.-_@=
auth_worker_max_count = 1
disable_plaintext_auth = no
doveadm_password = secret
doveadm_port = 12345
listen = server1
log_path = /var/log/dovecot.log
login_greeting = MAILBOX1 IMAP/POP3 server
mail_fsync = never
mail_gid = dovemail
mail_plugins = " notify replication quota"
mail_uid = dovemail
passdb {
   args = /etc/dovecot/dovecot-sql.conf.ext
   driver = sql
}
passdb {
   args = /etc/dovecot/dovecot-sql-master.conf.ext
   driver = sql
   master = yes
   pass = yes
}
plugin {
   mail_replica = tcp:server2:12345
   quota = dict:User quota::file:/var/lib/imap/%n/dovecot-quota
   quota_rule = *:storage=1GB
}
protocols = imap pop3 lmtp
service aggregator {
   fifo_listener replication-notify-fifo {
     user = dovemail
   }
   unix_listener replication-notify {
     user = dovemail
   }
}
service auth-worker {
   user = $default_internal_user
}
service auth {
   client_limit = 1024
   process_limit = 1
   process_min_avail = 1
}
service doveadm {
   inet_listener {
     port = 12345
   }
}
service imap {
   process_limit = 1024
   process_min_avail = 1
}
service lmtp {
   inet_listener {
     address = server1
     port = 24
   }
   process_limit = 256
   process_min_avail = 1
}
service pop3-login {
   inet_listener pop3 {
     address = server1
     port = 110
   }
}
service pop3 {
   process_limit = 256
   process_min_avail = 1
}
service replicator {
   process_min_avail = 1
}
ssl = no
userdb {
   driver = prefetch
}
userdb {
   args = /etc/dovecot/dovecot-sql.conf.ext
   driver = sql
}
verbose_proctitle = yes
protocol imap {
   imap_client_workarounds = tb-extra-mailbox-sep
   imap_idle_notify_interval = 2 mins
   imap_max_line_length = 64 k
   mail_max_userip_connections = 50
   mail_plugins = " notify replication quota imap_quota"
}
protocol lmtp {
   mail_fsync = optimized
   mail_plugins = " notify replication sieve quota"
}
protocol pop3 {
   mail_plugins = " notify replication quota"
}


More information about the dovecot mailing list