Patrick Welche <prlw1@cam.ac.uk>
[netbsd-mini2440.git] / external / ibm-public / postfix / dist / proto / ETRN_README.html
blob5f9bf7f0f2ea1255a22b3826a47c9c07f8b1066d
1 <!doctype html public "-//W3C//DTD HTML 4.01 Transitional//EN"
2 "http://www.w3.org/TR/html4/loose.dtd">
4 <html>
6 <head>
8 <title>Postfix ETRN Howto</title>
10 <meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
12 </head>
14 <body>
16 <h1><img src="postfix-logo.jpg" width="203" height="98" ALT="">Postfix ETRN Howto</h1>
18 <hr>
20 <h2>Purpose of the Postfix fast ETRN service</h2>
22 <p> The SMTP ETRN command was designed for sites that have intermittent
23 Internet connectivity. With ETRN, a site can tell the mail server
24 of its provider to "Please deliver all my mail now". The SMTP server
25 searches the queue for mail to the customer, and delivers that mail
26 <b>by connecting to the customer's SMTP server</b>. The mail is
27 not delivered via the connection that was used for sending ETRN.
28 </p>
30 <p> As of version 1.0, Postfix has a fast ETRN implementation that
31 does not require Postfix to examine every queue file. Instead,
32 Postfix maintains a record of what queue files contain mail for
33 destinations that are configured for ETRN service. ETRN service
34 is no longer available for domains that aren't configured for the
35 service. </p>
37 <p> This document provides information on the following topics: </p>
39 <ul>
41 <li><a href="#using">Using the Postfix fast ETRN service</a>
43 <li><a href="#how">How Postfix fast ETRN works</a>
45 <li><a href="#dirty_secret">Postfix fast ETRN service limitations</a>
47 <li><a href="#config">Configuring the Postfix fast ETRN service</a>
49 <li><a href="#only">Configuring a domain for ETRN service only</a>
51 <li><a href="#testing">Testing the Postfix fast ETRN service</a>
53 </ul>
55 <p> Other documents with information on this subject: </p>
57 <ul>
59 <li> flush(8), flush service implementation
61 </ul>
63 <h2><a name="using">Using the Postfix fast ETRN service</a> </h2>
65 <p> The following is an example SMTP session that shows how an SMTP
66 client requests the ETRN service. Client commands are shown in bold
67 font. </p>
69 <blockquote>
70 <pre>
71 220 my.server.tld ESMTP Postfix
72 <b>HELO my.client.tld</b>
73 250 Ok
74 <b>ETRN some.customer.domain</b>
75 250 Queuing started
76 <b>QUIT</b>
77 221 Bye
78 </pre>
79 </blockquote>
81 <p> As mentioned in the introduction, the mail is delivered by
82 connecting to the customer's SMTP server; it is not sent over
83 the connection that was used to send the ETRN command. </p>
85 <p> The Postfix operator can request delivery for a specific customer
86 by using the command "sendmail -qR<i>destination</i>" and, with
87 Postfix version 1.1 and later, "postqueue -s<i>destination</i>".
88 Access to this feature is controlled with the authorized_flush_users
89 configuration parameter (Postfix version 2.2 and later).
90 </p>
92 <h2><a name="how">How Postfix fast ETRN works</a></h2>
94 <p> When a Postfix delivery agent decides that mail must be delivered
95 later, it sends the destination domain name and the queue file name
96 to the flush(8) daemon which maintains per-destination logfiles
97 with file names of queued mail. These logfiles are kept below
98 $queue_directory/flush. Per-destination logfiles are maintained
99 only for destinations that are listed with the $fast_flush_domains
100 parameter and that have syntactically valid domain names. </p>
102 <blockquote>
104 <table>
106 <tr>
108 <td bgcolor="#f0f0ff" align="center" valign="middle"> Postfix<br>
109 delivery<br> agent</td>
111 <td> <tt>-</tt>(domain, queue ID)<tt>-&gt;</tt> </td>
113 <td bgcolor="#f0f0ff" align="center" valign="middle"> Postfix<br>
114 flush<br> daemon</td>
116 <td> <tt>-</tt>(queue ID)<tt>-&gt;</tt> </td>
118 <td bgcolor="#f0f0ff" align="center" valign="middle"> One logfile <br>
119 per eligible<br> domain </td>
121 </tr>
123 </table>
125 </blockquote>
127 <p> When Postfix receives a request to "deliver mail for a domain
128 now", the flush(8) daemon moves all deferred queue files that are
129 listed for that domain to the incoming queue, and requests that
130 the queue manager deliver them. In order to force delivery, the
131 queue manager temporarily ignores the lists of undeliverable
132 destinations: the volatile in-memory list of dead domains, and
133 the list of message delivery transports specified with the
134 defer_transports configuration parameter. </p>
136 <h2><a name="dirty_secret">Postfix fast ETRN service limitations</a></h2>
138 <p> The design of the flush(8) server and of the flush queue
139 introduce a few limitations that should not be an issue unless you
140 want to turn on fast ETRN service for every possible destination.
141 </p>
143 <ul>
145 <li> <p> The flush(8) daemon maintains per-destination logfiles
146 with queue file names. When a request to "deliver mail now" arrives,
147 Postfix will attempt to deliver all recipients in the queue files
148 that have mail for the destination in question. This does not
149 perform well with queue files that have recipients in many different
150 domains, such as queue files with outbound mailing list traffic.
151 </p>
153 <li> <p> The flush(8) daemon maintains per-destination logfiles
154 only for destinations listed with $fast_flush_domains. With other
155 destinations you cannot request delivery with "sendmail
156 -qR<i>destination</i>" or, with Postfix version 1.1 and later,
157 "postqueue -s<i>destination</i>". </p>
159 <li> <p> Up to and including early versions of Postfix version 2.1,
160 the "fast flush" service may not deliver some messages if the
161 request to "deliver mail now" is received while a deferred queue
162 scan is already in progress. The reason is that the queue manager
163 does not ignore the volatile in-memory list of dead domains, and
164 the list of message delivery transports specified with the
165 defer_transports configuration parameter. </p>
167 <li> <p> Up to and including Postfix version 2.3, the "fast flush"
168 service may not deliver some messages if the request to "deliver
169 mail now" arrives while an incoming queue scan is already in progress.
170 </p>
172 </ul>
174 <h2><a name="config">Configuring the Postfix fast ETRN service</a></h2>
176 <p> The behavior of the flush(8) daemon is controlled by parameters
177 in the main.cf configuration file. </p>
179 <p> By default, Postfix "fast ETRN" service is available only for
180 destinations that Postfix is willing to relay mail to: </p>
182 <blockquote>
183 <pre>
184 /etc/postfix/main.cf:
185 fast_flush_domains = $relay_domains
186 smtpd_etrn_restrictions = permit_mynetworks, reject
187 </pre>
188 </blockquote>
190 <p> Notes: </p>
192 <ul>
194 <li> <p> The relay_domains parameter specifies what destinations
195 Postfix will relay to. For destinations that are not eligible for
196 the "fast ETRN" service, Postfix replies with an error message.
197 </p>
199 <li> <p> The smtpd_etrn_restrictions parameter limits what clients
200 may execute the ETRN command. By default, any client has permission.
201 </p>
203 </ul>
205 <p> To enable "fast ETRN" for some other destination, specify: </p>
207 <blockquote>
208 <pre>
209 /etc/postfix/main.cf:
210 fast_flush_domains = $relay_domains, some.other.domain
211 </pre>
212 </blockquote>
214 <p> To disable "fast ETRN", so that Postfix rejects all ETRN requests
215 and so that it maintains no per-destination logfiles, specify: </p>
217 <blockquote>
218 <pre>
219 /etc/postfix/main.cf:
220 fast_flush_domains =
221 </pre>
222 </blockquote>
224 <h2><a name="only">Configuring a domain for ETRN service only</a></h2>
226 <p> While an "ETRN" customer is off-line, Postfix will make
227 spontaneous attempts to deliver mail to it. These attempts are
228 separated in time by increasing time intervals, ranging from
229 $minimal_backoff_time to $maximal_backoff_time, and should not be
230 a problem unless a lot of mail is queued. </p>
232 <p> To prevent Postfix from making spontaneous delivery attempts
233 you can configure Postfix to always defer mail for the "ETRN"
234 customer. Mail is delivered only after the ETRN command or with
235 "sendmail -q", with "sendmail -qR<i>domain</i>", or with "postqueue
236 -s<i>domain</i>"(Postfix version 1.1 and later only), </p>
238 <p> In the example below we configure an "etrn-only" delivery
239 transport which is simply a duplicate of the "smtp" and "relay"
240 mail delivery transports. The only difference is that mail destined
241 for this delivery transport is deferred as soon as it arrives.
242 </p>
244 <blockquote>
245 <pre>
246 1 /etc/postfix/master.cf:
247 2 # =============================================================
248 3 # service type private unpriv chroot wakeup maxproc command
249 4 # (yes) (yes) (yes) (never) (100)
250 5 # =============================================================
251 6 smtp unix - - n - - smtp
252 7 relay unix - - n - - smtp
253 8 etrn-only unix - - n - - smtp
255 10 /etc/postfix/main.cf:
256 11 relay_domains = customer.tld ...other domains...
257 12 defer_transports = etrn-only
258 13 transport_maps = hash:/etc/postfix/transport
260 15 /etc/postfix/transport:
261 16 customer.tld etrn-only:[mailhost.customer.tld]
262 </pre>
263 </blockquote>
265 <p>Translation: </p>
267 <ul>
269 <li> <p> Line 8: The "etrn-only" mail delivery service is a copy of the
270 "smtp" and "relay" service. </p>
272 <li> <p> Line 11: Don't forget to authorize relaying for this
273 customer, either via relay_domains or with the permit_mx_backup
274 feature. </p>
276 <li> <p> Line 12: The "etrn-only" mail delivery service is configured
277 so that spontaneous mail delivery is disabled. </p>
279 <li> <p> Lines 13-16: Mail for the customer is given to the
280 "etrn-only" mail delivery service. </p>
282 <li> <p> Line 16: The "[mailhost.customer.tld]" turns off MX record
283 lookups; you must specify this if your Postfix server is the primary
284 MX host for the customer's domain. </p>
286 </ul>
288 <h2><a name="testing">Testing the Postfix fast ETRN service</a></h2>
290 <p> By default, "fast ETRN" service is enabled for all domains that
291 match $relay_domains. If you run Postfix with "fast ETRN" service
292 for the very first time, you need to run "sendmail -q" once
293 in order to populate the per-site deferred mail logfiles. If you
294 omit this step, no harm is done. The logfiles will eventually
295 become populated as Postfix routinely attempts to deliver delayed
296 mail, but that will take a couple hours. After the "sendmail
297 -q" command has completed all delivery attempts (this can take
298 a while), you're ready to test the "fast ETRN" service.
300 <p> To test the "fast ETRN" service, telnet to the Postfix SMTP
301 server from a client that is allowed to execute ETRN commands (by
302 default, that's every client), and type the commands shown in
303 boldface: </p>
305 <blockquote>
306 <pre>
307 220 my.server.tld ESMTP Postfix
308 <b>HELO my.client.tld</b>
309 250 Ok
310 <b>ETRN some.customer.domain</b>
311 250 Queuing started
312 </pre>
313 </blockquote>
315 <p> where "some.customer.domain" is the name of a domain that has
316 a non-empty logfile somewhere under $queue_directory/flush. </p>
318 <p> In the maillog file, you should immediately see a couple of
319 logfile records, as evidence that the queue manager has opened
320 queue files: </p>
322 <blockquote>
323 <pre>
324 Oct 2 10:51:19 myhostname postfix/qmgr[51999]: 682E8440A4:
325 from=&lt;whatever&gt;, size=12345, nrcpt=1 (queue active)
326 Oct 2 10:51:19 myhostname postfix/qmgr[51999]: 02249440B7:
327 from=&lt;whatever&gt;, size=4711, nrcpt=1 (queue active)
328 </pre>
329 </blockquote>
331 <p> What happens next depends on whether the destination is reachable.
332 If it's not reachable, the mail queue IDs will be added back to
333 the some.customer.domain logfile under $queue_directory/flush.
334 </p>
336 <p> Repeat the exercise with some other destination that your server
337 is willing to relay to (any domain listed in $relay_domains), but
338 that has no mail queued. The text in bold face stands for the
339 commands that you type: </p>
341 <blockquote>
342 <pre>
343 220 my.server.tld ESMTP Postfix
344 <b>HELO my.client.tld</b>
345 250 Ok
346 <b>ETRN some.other.customer.domain</b>
347 250 Queuing started
348 </pre>
349 </blockquote>
351 <p> This time, the "ETRN"" command should trigger NO mail deliveries
352 at all. If this triggers delivery of all mail, then you used the
353 wrong domain name, or "fast ETRN" service is turned off. </p>
355 <p> Finally, repeat the exercise with a destination that your mail
356 server is not willing to relay to. It does not matter if your
357 server has mail queued for that destination. </p>
359 <blockquote>
360 <pre>
361 220 my.server.tld ESMTP Postfix
362 <b>HELO my.client.tld</b>
363 250 Ok
364 <b>ETRN not.a.customer.domain</b>
365 459 &lt;not.a.customer.domain&gt;: service unavailable
366 </pre>
367 </blockquote>
369 <p> In this case, Postfix should reject the request
370 as shown above. </p>
372 </body>
374 </html>