Milan Cvetkovic
2014-Mar-25  19:28 UTC
[Dovecot] Dovecot replication, no updates on message deposit
Hi,
I am trying to setup dovecot replication based on:
http://wiki2.dovecot.org/Replication
All mailboxes share the same UNIX userid ('vmail'), and I setup ssh-key 
based login for this account in both directions. As LDA exim4 is 
configured to use dovecot deliver LDA. Here is the relevant config from 
exim:
/usr/lib/dovecot/deliver -d $local_part -f $sender_address -a 
$original_local_part@$original_domain
When a message is deposited to a mailbox, it does not get replicated. 
The log is silent:
Mar 25 15:00:20 mx02 dovecot: master: Dovecot v2.2.9 starting up (core 
dumps disabled)
Mar 25 15:01:05 mx02 dovecot: lda(user.name): msgid=unspecified: saved 
mail to INBOX
The output from doveconf -n is attached.
Any help is appreciated,
Thanks, Milan.
-------------- next part --------------
# 2.2.9: /etc/dovecot/dovecot.conf
# OS: Linux 3.2.0-4-amd64 x86_64 Debian 7.4 
auth_mechanisms = plain login
mail_location = maildir:~/Maildir
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 ihave
namespace inbox {
  inbox = yes
  location = 
  mailbox Drafts {
    special_use = \Drafts
  }
  mailbox Junk {
    special_use = \Junk
  }
  mailbox Sent {
    special_use = \Sent
  }
  mailbox "Sent Messages" {
    special_use = \Sent
  }
  mailbox Trash {
    special_use = \Trash
  }
  prefix = 
}
passdb {
  args = /etc/dovecot/dovecot-sql.conf.ext
  driver = sql
}
plugin {
  mail_replica = remote:vmail at 192.168.108.136
  sieve = ~/.dovecot.sieve
  sieve_dir = ~/sieve
}
protocols = " imap sieve pop3"
replication_full_sync_interval = 1 hours
service aggregator {
  fifo_listener replication-notify-fifo {
    user = vmail
  }
  unix_listener replication-notify {
    user = vmail
  }
}
service auth {
  unix_listener auth-client {
    mode = 0660
    user = Debian-exim
  }
}
service replicator {
  process_min_avail = 1
  unix_listener replicator-doveadm {
    mode = 0600
  }
}
ssl_cert = </etc/exim4/exim.crt
ssl_key = </etc/exim4/exim.key
userdb {
  driver = prefetch
}
userdb {
  args = /etc/dovecot/dovecot-sql.conf.ext
  driver = sql
}
protocol lda {
  mail_plugins = " sieve"
}
Milan Cvetkovic
2014-Mar-27  16:58 UTC
[Dovecot] Dovecot replication, no updates on message deposit
If anyone is interested - I found the problem in my setup:
 > protocol lda {
 >    mail_plugins = " sieve"
 > }
needs to have both "replication" and "notify"
protocol lda {
     mail_plugins = " sieve replication notify"
}
Maybe it is just me, but the Replication wiki page is not detailed 
enough. I had lots of problems trying to figure out which process runs 
on which machine, and in the context of which user.
For example, the first note mentions that "doveadm user '*'"
has to
work. It does not the context when this command would be running. This 
is important, because it takes 2 steps to configure it properly:
- to make sure the command runs at all - configure the userdb properly
- to make sure the UNIX user account which would be running it has
   the right to do it.
As a result, there are couple of posts on this list bumping up 
permissions to various sockets/fifos in /var/run/dovecot directory, 
probably in attempts to let 'vmail' user run "doveadm user
'*'". And I
still don't know if 'vmail' user runs it or not...
Milan
exim is configured to use dovecot's deliver as LDA.
Milan Cvetkovic wrote:> Hi,
>
> I am trying to setup dovecot replication based on:
>
> http://wiki2.dovecot.org/Replication
>
> All mailboxes share the same UNIX userid ('vmail'), and I setup
ssh-key
> based login for this account in both directions. As LDA exim4 is
> configured to use dovecot deliver LDA. Here is the relevant config from
> exim:
>
> /usr/lib/dovecot/deliver -d $local_part -f $sender_address -a
> $original_local_part@$original_domain
>
>
> When a message is deposited to a mailbox, it does not get replicated.
> The log is silent:
>
> Mar 25 15:00:20 mx02 dovecot: master: Dovecot v2.2.9 starting up (core
> dumps disabled)
> Mar 25 15:01:05 mx02 dovecot: lda(user.name): msgid=unspecified: saved
> mail to INBOX
>
> The output from doveconf -n is attached.
>
> Any help is appreciated,
>
> Thanks, Milan.
>
> doveconf-n.txt
>
>
> # 2.2.9: /etc/dovecot/dovecot.conf
> # OS: Linux 3.2.0-4-amd64 x86_64 Debian 7.4
> auth_mechanisms = plain login
> mail_location = maildir:~/Maildir
> 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 ihave
> namespace inbox {
>    inbox = yes
>    location >    mailbox Drafts {
>      special_use = \Drafts
>    }
>    mailbox Junk {
>      special_use = \Junk
>    }
>    mailbox Sent {
>      special_use = \Sent
>    }
>    mailbox "Sent Messages" {
>      special_use = \Sent
>    }
>    mailbox Trash {
>      special_use = \Trash
>    }
>    prefix > }
> passdb {
>    args = /etc/dovecot/dovecot-sql.conf.ext
>    driver = sql
> }
> plugin {
>    mail_replica = remote:vmail at 192.168.108.136
>    sieve = ~/.dovecot.sieve
>    sieve_dir = ~/sieve
> }
> protocols = " imap sieve pop3"
> replication_full_sync_interval = 1 hours
> service aggregator {
>    fifo_listener replication-notify-fifo {
>      user = vmail
>    }
>    unix_listener replication-notify {
>      user = vmail
>    }
> }
> service auth {
>    unix_listener auth-client {
>      mode = 0660
>      user = Debian-exim
>    }
> }
> service replicator {
>    process_min_avail = 1
>    unix_listener replicator-doveadm {
>      mode = 0600
>    }
> }
> ssl_cert = </etc/exim4/exim.crt
> ssl_key = </etc/exim4/exim.key
> userdb {
>    driver = prefetch
> }
> userdb {
>    args = /etc/dovecot/dovecot-sql.conf.ext
>    driver = sql
> }
> protocol lda {
>    mail_plugins = " sieve"
> }
>