source: server/mail/dovecot-systemd.xml@ 1be4837c

krejzi/svn
Last change on this file since 1be4837c was 1be4837c, checked in by Krejzi <krejzi@…>, 10 years ago

Convert entire Servers section.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/branches/krejzi@14757 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 10.3 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY dovecot-download-http
8 "http://www.dovecot.org/releases/&dovecot-major;.&dovecot-minor;/dovecot-&dovecot-version;.tar.gz">
9 <!ENTITY dovecot-download-ftp " ">
10 <!ENTITY dovecot-md5sum "c6c176943bd832c780fbb5d2f8850952">
11 <!ENTITY dovecot-size "4.6 MB">
12 <!ENTITY dovecot-buildsize "164 MB">
13 <!ENTITY dovecot-time "1.4 SBU (additional 0.5 SBU for the tests)">
14]>
15
16<sect1 id="dovecot" xreflabel="Dovecot-&dovecot-version;">
17 <?dbhtml filename="dovecot.html"?>
18
19 <sect1info>
20 <othername>$LastChangedBy$</othername>
21 <date>$Date$</date>
22 </sect1info>
23
24 <title>Dovecot-&dovecot-version;</title>
25
26 <indexterm zone="dovecot">
27 <primary sortas="a-Dovecot">Dovecot</primary>
28 </indexterm>
29
30 <sect2 role="package">
31 <title>Introduction to Dovecot</title>
32
33 <para>
34 <application>Dovecot</application> is an Internet Message Access Protocol
35 (IMAP) and Post Office Protocol (POP) server, written primarily with
36 security in mind. <application>Dovecot</application> aims to be
37 lightweight, fast and easy to set up as well as highly configurable and
38 easily extensible with plugins.
39 </para>
40
41 &lfs76_checked;
42
43 <bridgehead renderas="sect3">Package Information</bridgehead>
44 <itemizedlist spacing="compact">
45 <listitem>
46 <para>
47 Download (HTTP): <ulink url="&dovecot-download-http;"/>
48 </para>
49 </listitem>
50 <listitem>
51 <para>
52 Download (FTP): <ulink url="&dovecot-download-ftp;"/>
53 </para>
54 </listitem>
55 <listitem>
56 <para>
57 Download MD5 sum: &dovecot-md5sum;
58 </para>
59 </listitem>
60 <listitem>
61 <para>
62 Download size: &dovecot-size;
63 </para>
64 </listitem>
65 <listitem>
66 <para>
67 Estimated disk space required: &dovecot-buildsize;
68 </para>
69 </listitem>
70 <listitem>
71 <para>
72 Estimated build time: &dovecot-time;
73 </para>
74 </listitem>
75 </itemizedlist>
76
77 <bridgehead renderas="sect3">Dovecot Dependencies</bridgehead>
78
79 <bridgehead renderas="sect4">Optional</bridgehead>
80 <para role="optional">
81 <xref linkend="clucene"/>,
82 <xref linkend="linux-pam"/>,
83 <xref linkend="mariadb"/>,
84 <xref linkend="openldap"/>,
85 <xref linkend="openssl"/>,
86 <xref linkend="postgresql"/>,
87 <xref linkend="sqlite"/>, and
88 <xref linkend="valgrind"/>
89 </para>
90
91 <para condition="html" role="usernotes">User Notes:
92 <ulink url="&blfs-wiki;/dovecot"/>
93 </para>
94 </sect2>
95
96 <sect2 role="installation">
97 <title>Installation of Dovecot</title>
98
99 <para>
100 There should be dedicated users and groups for unprivileged Dovecot
101 processes and for processing users' logins. Issue the following commands
102 as the <systemitem class="username">root</systemitem> user:
103 </para>
104
105<screen role="root"><userinput>groupadd -g 42 dovecot &amp;&amp;
106useradd -c "Dovecot unprivileged user" -d /dev/null -u 42 \
107 -g dovecot -s /bin/false dovecot &amp;&amp;
108groupadd -g 43 dovenull &amp;&amp;
109useradd -c "Dovecot login user" -d /dev/null -u 43 \
110 -g dovenull -s /bin/false dovenull</userinput></screen>
111
112 <para>
113 Install <application>Dovecot</application> by running the following
114 commands:
115 </para>
116
117<screen><userinput>./configure --prefix=/usr \
118 --sysconfdir=/etc \
119 --localstatedir=/var \
120 --docdir=/usr/share/doc/dovecot-&dovecot-version; \
121 --disable-static \
122 --with-systemdsystemunitdir=/lib/systemd/system &amp;&amp;
123make</userinput></screen>
124
125 <para>To test the results, issue <command>make -k check</command>. One test
126 fails for unknown reason</para>
127
128 <para>
129 Now, as the <systemitem class="username">root</systemitem> user:
130 </para>
131
132<screen role="root"><userinput>make install</userinput></screen>
133
134 </sect2>
135
136 <sect2 role="commands">
137 <title>Command Explanations</title>
138
139 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
140 href="../../xincludes/static-libraries.xml"/>
141
142 <para>
143 <parameter>--with-systemdsystemunitdir=/lib/systemd/system</parameter>:
144 This switch is used to set the correct installation directory for
145 systemd units.
146 </para>
147
148 <para>
149 <option>--with-ldap</option>: This switch enables
150 <application>OpenLDAP</application> authentication support.
151 </para>
152
153 <para>
154 <option>--with-pgsql</option>: This switch enables
155 <application>PostgreSQL</application> authentication support.
156 </para>
157
158 <para>
159 <option>--with-mysql</option>: This switch enables
160 <application>MySQL</application> authentication support.
161 </para>
162
163 <para>
164 <option>--with-sqlite</option>: This switch enables
165 <application>SQLite</application> authentication support.
166 </para>
167
168 <para>
169 <option>--with-lucene</option>: This switch enables
170 <application>CLucene</application> full text search support.
171 </para>
172
173 </sect2>
174
175 <sect2 role="configuration">
176 <title>Configuring Dovecot</title>
177
178 <sect3 id="dovecot-config">
179 <title>Config Files</title>
180
181 <para>
182 <filename>/etc/dovecot/dovecot.conf</filename>,
183 <filename>/etc/dovecot/conf.d/*</filename>, and
184 <filename>/etc/dovecot/local.conf</filename>
185 </para>
186
187 <indexterm zone="dovecot dovecot-config">
188 <primary sortas="e-etc-dovecot-dovecot.conf">/etc/dovecot/dovecot.conf</primary>
189 </indexterm>
190 <indexterm zone="dovecot dovecot-config">
191 <primary sortas="e-etc-dovecot-conf.d">/etc/dovecot/conf.d/*</primary>
192 </indexterm>
193 <indexterm zone="dovecot dovecot-config">
194 <primary sortas="e-etc-dovecot-local.conf">/etc/dovecot/local.conf</primary>
195 </indexterm>
196
197 </sect3>
198
199 <sect3>
200 <title>Configuration Information</title>
201
202 <para>
203 Copy an example configuration, which you can use as a starting point:
204 </para>
205
206<screen role="root"><userinput>cp -rv /usr/share/doc/dovecot-&dovecot-version;/example-config/* /etc/dovecot</userinput></screen>
207
208 <para>
209 The following configuration is a simple proof of concept with IMAP
210 service using local users for authentication and mailbox location.
211 Reading files from the <filename class="directory">conf.d</filename>
212 directory is commented out since the included example configuration
213 requires <application>OpenSSL</application> and
214 <application>Linux PAM</application>.
215 </para>
216
217<screen role="root"><userinput>sed -i '/^\!include / s/^/#/' /etc/dovecot/dovecot.conf &amp;&amp;
218chmod -v 1777 /var/mail &amp;&amp;
219cat &gt; /etc/dovecot/local.conf &lt;&lt; "EOF"
220<literal>protocols = imap
221ssl = no
222# The next line is only needed if you have no IPv6 network interfaces
223listen = *
224mail_location = mbox:~/Mail:INBOX=/var/mail/%u
225userdb {
226 driver = passwd
227}
228passdb {
229 driver = shadow
230}</literal>
231EOF</userinput></screen>
232
233 <para>
234 You will definitely want to read the official documentation at <ulink
235 url="http://wiki2.dovecot.org/"/> if you plan to use
236 <application>Dovecot</application> in production environment.
237 </para>
238
239 </sect3>
240
241 <sect3 id="dovecot-init">
242 <title>Systemd Units</title>
243
244 <para>
245 To start the <command>dovecot</command> daemon at boot,
246 install the systemd unit from the <xref linkend="bootscripts"/>
247 package by running the following command as the
248 <systemitem class="username">root</systemitem> user:
249 </para>
250
251 <indexterm zone="dovecot dovecot-init">
252 <primary sortas="f-dovecot">dovecot</primary>
253 </indexterm>
254
255<screen role="root"><userinput>systemctl enable dovecot</userinput></screen>
256
257 </sect3>
258
259 </sect2>
260
261 <sect2 role="content">
262 <title>Contents</title>
263
264 <segmentedlist>
265 <segtitle>Installed Programs</segtitle>
266 <segtitle>Installed Libraries</segtitle>
267 <segtitle>Installed Directories</segtitle>
268
269 <seglistitem>
270 <seg>
271 doveadm, doveconf, dovecot, dsync, and various internal programs
272 </seg>
273 <seg>
274 various internal plugins
275 </seg>
276 <seg>
277 /etc/dovecot,
278 /usr/include/dovecot,
279 /usr/lib/dovecot,
280 /usr/libexec/dovecot, and
281 /usr/share/doc/dovecot-&dovecot-version;
282 </seg>
283 </seglistitem>
284 </segmentedlist>
285
286 <variablelist>
287 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
288 <?dbfo list-presentation="list"?>
289 <?dbhtml list-presentation="table"?>
290
291 <varlistentry id="doveadm">
292 <term><command>doveadm</command></term>
293 <listitem>
294 <para>
295 is the <application>Dovecot</application> administration tool.
296 </para>
297 <indexterm zone="dovecot doveadm">
298 <primary sortas="b-doveadm">doveadm</primary>
299 </indexterm>
300 </listitem>
301 </varlistentry>
302
303 <varlistentry id="doveconf">
304 <term><command>doveconf</command></term>
305 <listitem>
306 <para>
307 is <application>Dovecot</application>'s configuration dumping
308 utility.
309 </para>
310 <indexterm zone="dovecot doveconf">
311 <primary sortas="b-doveconf">doveconf</primary>
312 </indexterm>
313 </listitem>
314 </varlistentry>
315
316 <varlistentry id="dovecot-prog">
317 <term><command>dovecot</command></term>
318 <listitem>
319 <para>
320 is the IMAP and POP server.
321 </para>
322 <indexterm zone="dovecot dovecot-prog">
323 <primary sortas="b-dovecot">dovecot</primary>
324 </indexterm>
325 </listitem>
326 </varlistentry>
327
328 <varlistentry id="dsync">
329 <term><command>dsync</command></term>
330 <listitem>
331 <para>
332 is <application>Dovecot</application>'s mailbox synchronization
333 utility.
334 </para>
335 <indexterm zone="dovecot dsync">
336 <primary sortas="b-dsync">dsync</primary>
337 </indexterm>
338 </listitem>
339 </varlistentry>
340
341
342 </variablelist>
343
344 </sect2>
345
346</sect1>
Note: See TracBrowser for help on using the repository browser.