summaryrefslogtreecommitdiffstats
path: root/doc/wiki/RunningDovecot.txt
blob: 05208462c3387fd05d125738a96d54faf694ce1d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
Running Dovecot
===============

Starting
--------

Dovecot can simply be started by running 'dovecot' as root. If there are any
problems, they're usually written to terminal, but they may also be written to
<error log> [Logging.txt] as well.

 * A sample universal <init.d script> [DovecotInit.txt].
 * A sample Mac OS X 10.4 <launchd plist file> [LaunchdInstall.txt]

Stopping
--------

Killing the Dovecot master process with a normal TERM signal does a clean
shutdown. This can be done easily with:

---%<-------------------------------------------------------------------------
doveadm stop
---%<-------------------------------------------------------------------------

'shutdown_clients' setting controls whether existing IMAP and POP3 sessions are
killed.

Processes
---------

When Dovecot is running, it uses several processes:

---%<-------------------------------------------------------------------------
# ps auxw|grep "dovecot"
root      7245  0.1  0.1   2308  1096 pts/0    S+   19:53   0:00 dovecot
dovecot   7246  0.0  0.0   2084   824 pts/0    S+   19:53   0:00 dovecot/anvil
root      7247  0.0  0.0   2044   908 pts/0    S+   19:53   0:00 dovecot/log
root      7250  0.0  0.3   4988  3740 pts/0    S+   19:53   0:00 dovecot/config
root      7251  0.0  0.2  10024  2672 pts/0    S+   19:53   0:00 dovecot/auth
root      7303  0.6  0.3  10180  3116 pts/0    S+   19:57   0:00 dovecot/auth
-w
vmail     7252  0.0  0.1   3180  1264 pts/0    S+   19:53   0:00 dovecot/imap
vmail     7255  0.0  0.1   3228  1596 pts/0    S+   19:54   0:00 dovecot/pop3
dovenull  7260  0.0  0.1   4028  1940 pts/0    S+   19:54   0:00
dovecot/imap-login
dovenull  7262  0.0  0.1   4016  1916 pts/0    S+   19:54   0:00
dovecot/pop3-login
---%<-------------------------------------------------------------------------

 * 'dovecot' process is the Dovecot master process which keeps everything
   running.
 * 'anvil' keeps track of user connections
 * 'log' writes to log files. All logging, except from master process, goes
   through it.
 * 'config' parses the configuration file and sends the configuration to other
   processes.
 * 'auth' handles all authentication.
 * 'auth -w' process is an "authentication worker" process. It's used only with
   some "blocking" authentication databases, such as MySQL.
 * 'imap-login' and 'pop3-login' processes handle new IMAP and POP3 connections
   until user has logged in. They also handle proxying SSL connections even
   after login.
 * 'imap' and 'pop3' processes handle the IMAP and POP3 connections after user
   has logged in.

Reloading Configuration
-----------------------

Sending HUP signal to Dovecot reloads configuration. This can be done easily
with:

---%<-------------------------------------------------------------------------
doveadm reload
---%<-------------------------------------------------------------------------

An acknowledgement is written to log file:

---%<-------------------------------------------------------------------------
Jun 14 19:59:59 master: Warning: SIGHUP received - reloading configuration
---%<-------------------------------------------------------------------------

Running Multiple Invocations of Dovecot
---------------------------------------

You may wish to invoke a second session (or even multiple sessions) of Dovecot
for testing different functionality, configurations, etc.  In order to run
multiple instances of Dovecot, you must:

 1. Create a differently named copy of the dovecot.conf configuration file with
    these changes:
     1. Change 'base_dir' to the new run directory
     2. Change services' inet_listener port numbers to new, unused values (in
        '10-master.conf').
     3. Optionally change 'instance_name' to show a different "dovecot/" prefix
        in ps output. (v2.0.18+)
     4. If you're using authentication sockets (for SMTP AUTH or deliver),
        you'll need to change them as well.'auth_socket_path' specifies the
        socket path for deliver.
         * Alternatively if all the instances have identical authentication
           configuration, you can have only a single Dovecot instance serve the
           auth sockets and have the other instances use them.
 2. Invoke 'dovecot' (and 'dovecot-lda') with the '-c' parameter and the
    modified configuration file, e.g.:'dovecot -c /usr/local/etc/dovecot2.conf'

 3. In order to tell the logs apart, you can set different log facilities for
    the instances, e.g.'syslog_facility=local6', then configure syslogd to
    write local6 into "dovecot-otherinstance.log". Alternatively specify the
    log paths directly in 'log_path' and related settings.

Rotating Log Files
------------------

If you specified log file paths manually in 'dovecot.conf' instead of using
syslog, you can send USR1 signal to Dovecot to make it close and reopen the log
files. This can be done easily with:

---%<-------------------------------------------------------------------------
doveadm log reopen
---%<-------------------------------------------------------------------------

Troubleshooting
---------------

If you can't see the Dovecot processes running after starting 'dovecot',
something is most likely wrong in your 'dovecot.conf'. Look at the error from
Dovecot's log file. See <Logging.txt> for how to find the log.

If you really can't find any error messages from any logs, try starting Dovecot
with 'dovecot -F'. If you see it crash like:

---%<-------------------------------------------------------------------------
sh: segmentation fault (core dumped)  dovecot -F
---%<-------------------------------------------------------------------------

Then it's a bug in Dovecot. Please report it with your configuration file.

If it simply quits without giving any error, then it wrote the error to a log
file and you just didn't find it. Try specifying the log file manually and make
sure you're really looking at the correct file.

(This file was created from the wiki on 2019-06-19 12:42)