doveadm-sync.1.in revision e7f1247b5ae1290974f9e078ad46c2b6809b2636
Copyright (c) 2014-2015 Dovecot authors, see the included COPYING file
DOVEADM-SYNC 1 "2015-05-09" "Dovecot v2.2" "Dovecot"
NAME
doveadm-sync - Dovecot\(aqs two-way mailbox synchronization utility

doveadm-backup - Dovecot\(aqs one-way mailbox synchronization utility ------------------------------------------------------------------------

SYNOPSIS
doveadm " [" -Dv "] " sync [-u user|-A|-F file] [-S socket_path] [ -1fPRU ] [-l secs] [-r rawlog_path] [-m mailbox] [-g mailbox_guid] [-n namespace|-N] [-x exclude] [-s state] -d|destination -------------------------------------

doveadm " [" -Dv "] " backup [-u user|-A|-F file] [-S socket_path] [ -fPRU ] [-l secs] [-r rawlog_path] [-m mailbox] [-g mailbox_guid] [-n namespace|-N] [-x exclude] [-s state] -d|destination ------------------------------------------------------------------------

DESCRIPTION
dsync is Dovecot\(aqs mailbox synchronization utility. It can be used for several different use cases: Two-way synchronization of mailboxes, creating backups of mails, and convert mailboxes from/to different mailbox formats. All of these can be used within the same server or between different servers (via ssh (1) or tcp connections). Remote mailboxes can be accessed also via IMAP protocol, which allows using dsync for mailbox migration purposes.

You can run dsync in one of three modes:

-------------------------------------

\(bu
doveadm backup performs one-way synchronization. If there are any changes in the destination they will be deleted, so the destination will look exactly like the source. -------------------------------------
\(bu
doveadm sync performs two-way synchronization. It merges all changes without losing anything. Both the mailboxes will end up looking identical after the synchronization is finished. -------------------------------------
\(bu
doveadm sync -1 performs one-way synchronization, but it merges the changes in destination without deleting anything. This doesn\(aqt currently work perfectly, so its use should be limited. Its main purpose is that during mailbox migration you can run doveadm backup multiple times, then switch mails to be delivered to the new mailbox and run doveadm sync -1 once more to transfer any last new mails from the old mailbox. -------------------------------------

There are also three different synchronization algorithms:

-------------------------------------

\(bu
Full synchronization (-f parameter) scans through all the messages in all the mailboxes. This guarantees that everything will be synchronized, but it\(aqs unnecessarily slow for incremental synchronization. -------------------------------------
\(bu
Fast synchronization (default) first attempts to find mailboxes that have changed, and synchronize only those. This is done by checking the mailboxes\(aq metadata (NEXTUID and HIGHESTMODSEQ). Usually this works fine, especially with one-way synchronization, but if both sides do exactly the same number of changes, the metadata may end up containing the same values even if the changes were different. -------------------------------------
\(bu
Stateful synchronization (-s parameter) is the most efficient way to synchronize mailboxes. It relies on having the earlier dsync run\(aqs state saved somewhere and being passed to the next dsync run. Based on this state dsync can send only the changes that happened after the previous dsync run. As long as the state or the mailboxes aren\(aqt corrupted this algorithm should work perfectly. The replicator process uses this internally to perform most of the synchronization. -------------------------------------

The syncing is done as perfectly as possible: an IMAP or a POP3 client shouldn\(aqt be able to notice any differences between the two mailboxes. Two-way syncing means that it\(aqs safe to do any kind of modifications in both sides, and dsync will merge the changes without losing any changes done on either side. This is possible because dsync can access Dovecot\(aqs index logs that keep track of changes. It\(aqs of course possible to have conflicts during merging, these are resolved in a safe way. See the dsync design document for more information.

dsync uses the same configuration files as the rest of Dovecot (via doveconf (1) binary). The entire configuration can be changed by giving -c parameter to another configuration file, or using -o parameter to override specific settings. When executing a remote dsync program it works the same way: it uses its own local configuration.

dsync can be run completely standalone. It doesn\(aqt require any Dovecot server processes to be running, except when using -u parameter to do a userdb lookup from auth process.

dsync can sync either one or multiple users using the -u or -A parameters. For continuous replication you can use the Dovecot replicator process, which automatically runs dsync whenever messages have changed. ------------------------------------------------------------------------
@INCLUDE:global-options@ --- command specific options --- "/.

Command specific options :

-1 Do one-way synchronization instead of two-way synchronization. -------------------------------------
@INCLUDE:option-A@ -------------------------------------
@INCLUDE:option-F-file@ -------------------------------------

-N Synchronize all the available namespaces. By default only namespaces that don\(aqt have explicit location setting are synchronized. -------------------------------------

-P Run a doveadm-purge (1) for the destination (remote) storage after synchronization. -------------------------------------
@INCLUDE:option-S-socket@ -------------------------------------

-U This is used internally by replicator to have dsync notify it when the synchronization is finished. -------------------------------------

-d Use the default destination, which is looked up from the mail_replica userdb extra field. -------------------------------------

-g mailbox_guid Same as -m, but find the mailbox to be synchronized by its GUID instead of by name. -------------------------------------

-l secs Lock the dsync for this user. Wait for maximum secs before giving up. This parameter should be used to avoid broken synchronization if it\(aqs possible that dsync is being run concurrently for the same user. -------------------------------------

-n namespace Synchronize only the specified namespace. This parameter can be used multiple times. -------------------------------------

-r rawlog_path Running dsync remotely, write the remote input/output traffic to the specified log file. -------------------------------------

-s previous_state Use stateful synchronization. If the previous state is unknown, use an empty string. The new state is always printed to standard output. -------------------------------------
@INCLUDE:option-u-user@ -------------------------------------

-x mailbox_mask Exclude the specified mailbox name/mask. The mask may contain \(dq?\(dq and \(dq*\(dq wildcards. This parameter can be used multiple times. ------------------------------------------------------------------------

ARGUMENTS

destination This argument specifies the synchronized destination. It can be one of:

location Same as mail_location setting, e.g. maildir:\(ti/Maildir

remote: login@host Uses dsync_remote_cmd setting to connect to the remote host (usually via ssh)

remoteprefix:login@host This is the same as remote, except \(dquser@domain\(rsn\(dq is sent before dsync protocol starts. This allows implementing a trusted wrapper script that runs doveadm dsync-server by reading the username from the first line.

tcp: host[:port] Connects to remote doveadm server via TCP. The default port is specified by doveadm_port " setting."

tcps: host[:port] This is the same as tcp, but with SSL.

------------------------------------------------------------------------
"EXIT STATUS"
dsync will exit with one of the following values:

4 0 Synchronization was done perfectly.

2 Synchronization was done without errors, but some changes couldn\(aqt be done, so the mailboxes aren\(aqt perfectly synchronized. Running dsync again usually fixes this. Typically this occurs for message modification sequences with newly created mailboxes. It can also occur if one of the mailboxes change during the syncing.

1, >2 Synchronization failed. ------------------------------------------------------------------------

EXAMPLE
SYNCHRONIZATION
Synchronize mailboxes with a remote server. Any errors are written to stderr.

doveadm sync -u username@example.com remote:server-replica.example.com

If you need more complex parameters to ssh, you can use e.g.:

doveadm sync -u username@example.com ssh -i id_dsa.dovecot \(rs
mailuser@example.com doveadm dsync-server -u username@example.com
------------------------------------------------------------------------
CONVERTING
Assuming that the mail_location setting in @pkgsysconfdir@/conf.d/10-mail.conf is set to: "mail_location = mdbox:\(ti/mdbox" , a logged in system user may convert her/his mails from its Maildir in her/his home directory to the mdbox mailbox format. The user has to execute the command:

doveadm sync maildir:\(ti/Maildir

If you want to do this without any downtime, you can do the conversion one user at a time. Initially:

\(bu 4
Configuration uses mail_location = maildir:\(ti/Maildir
\(bu
Set up the possibility of doing per-user mail location using userdb extra fields.

Then for each user:

1. 4
Run doveadm sync once to do the initial conversion.
2.
Run doveadm sync again, because the initial conversion could have taken a while and new changes could have occurred during it. This second time only applies changes, so it should be fast.
3.
Update mail extra field in userdb to mdbox:\(ti/mdbox . If you\(aqre using auth cache, you need to flush it, e.g. "doveadm auth cache flush" .
4.
Wait for a few seconds and then kill (doveadm kick) the user\(aqs all existing imap and pop3 sessions (that are still using maildir).
5.
Run doveadm sync once more to apply final changes that were possibly done. After this there should be no changes to Maildir, because the user\(aqs mail location has been changed and all existing processes using it have been killed.

Once all users have been converted, you can set the default mail_location to mdbox and remove the per-user mail locations from userdb . ------------------------------------------------------------------------
@INCLUDE:reporting-bugs@ ------------------------------------------------------------------------

SEE ALSO
doveadm (1), doveadm-auth (1), doveadm-kick (1), doveadm-purge (1), doveconf (1) -------------------------------------

Additional resources:

"dsync design"
http://wiki2.dovecot.org/Design/Dsync