data:image/s3,"s3://crabby-images/9f085/9f085b5ee04e5f0d67360382f3d58e13e4a3107f" alt=""
Hi, when I try to send an e-mail to my list (only one recipient, the list itself), I get these:
In mailman's smtp logs: Oct 22 13:26:17 2012 (22940) <xxxxxxx> smtp to contas for 828 recips, completed in 1.705 seconds
In mailman's post logs: Oct 22 13:26:17 2012 (22940) post to contas from xxx@xxxx, size=3620, message-id=<xxxxxxx>, 450 failures
In mailman's smtp-failure logs: Oct 22 13:26:17 2012 (22940) delivery to xxx@xxxxx failed with code 452: 4.5.3 Error: too many recipients
In my mm_cfg.py I have this: DEFAULT_MAX_NUM_RECIPIENTS = 0
Any ideas?
data:image/s3,"s3://crabby-images/9f085/9f085b5ee04e5f0d67360382f3d58e13e4a3107f" alt=""
Citando Rodrigo Abrantes Antunes <rodrigoantunes@pelotas.ifsul.edu.br>:
Hi, when I try to send an e-mail to my list (only one recipient, the
list itself), I get these:In mailman's smtp logs: Oct 22 13:26:17 2012 (22940) <xxxxxxx> smtp to contas for 828
recips, completed in 1.705 secondsIn mailman's post logs: Oct 22 13:26:17 2012 (22940) post to contas from xxx@xxxx,
size=3620, message-id=<xxxxxxx>, 450 failuresIn mailman's smtp-failure logs: Oct 22 13:26:17 2012 (22940) delivery to xxx@xxxxx failed with
code 452: 4.5.3 Error: too many recipientsIn my mm_cfg.py I have this: DEFAULT_MAX_NUM_RECIPIENTS = 0
Any ideas?
Searching google I found that this error isn't related to the number of users in the list, it occurs because the total number of addresses in the To: and Cc: headers of the post equals or exceeds max_num_recipients. But in documentation is said that if this option is set to 0 it has no limit. And my post have only one recipient in To:, the list itself. So what may be causing this?
data:image/s3,"s3://crabby-images/f3471/f34712d6605da5f4b109bdeb7699788bd79eff5e" alt=""
Am I understanding correctly that the list itself is a member of the list? Sounds like an email loop to me. What are you trying to do?
-- Gary Kalbfleisch -- Director of Technology Support Services -- Shoreline Community College -- (206) 546-5813 -- (206) 546-6943 Fax
-----Original Message----- From: Mailman-Users [mailto:mailman-users- bounces+garyk=shoreline.edu@python.org] On Behalf Of Rodrigo Abrantes Antunes Sent: Tuesday, October 23, 2012 9:19 AM To: mailman-users@python.org Subject: Re: [Mailman-Users] Too many recipients
Citando Rodrigo Abrantes Antunes <rodrigoantunes@pelotas.ifsul.edu.br>:
Hi, when I try to send an e-mail to my list (only one recipient, the list itself), I get these:
In mailman's smtp logs: Oct 22 13:26:17 2012 (22940) <xxxxxxx> smtp to contas for 828 recips, completed in 1.705 seconds
In mailman's post logs: Oct 22 13:26:17 2012 (22940) post to contas from xxx@xxxx, size=3620, message-id=<xxxxxxx>, 450 failures
In mailman's smtp-failure logs: Oct 22 13:26:17 2012 (22940) delivery to xxx@xxxxx failed with code 452: 4.5.3 Error: too many recipients
In my mm_cfg.py I have this: DEFAULT_MAX_NUM_RECIPIENTS = 0
Any ideas?
Searching google I found that this error isn't related to the number of users in the list, it occurs because the total number of addresses in the To: and Cc: headers of the post equals or exceeds max_num_recipients. But in documentation is said that if this option is set to 0 it has no limit. And my post have only one recipient in To:, the list itself. So what may be causing this?
Mailman-Users mailing list Mailman-Users@python.org http://mail.python.org/mailman/listinfo/mailman-users Mailman FAQ: http://wiki.list.org/x/AgA3 Security Policy: http://wiki.list.org/x/QIA9 Searchable Archives: http://www.mail- archive.com/mailman-users%40python.org/ Unsubscribe: http://mail.python.org/mailman/options/mailman- users/garyk%40shoreline.edu
data:image/s3,"s3://crabby-images/d8997/d8997862bf32685c4606ed1b7400f74ade85b899" alt=""
Hi, when I try to send an e-mail to my list (only one recipient, the list itself), I get these:
Aren't you creating a loop here? Why are you putting the list itself on the list as its only recipient? This appears to me to be an invitation for an endless loop.
-- Lindsay Haisley | "Real programmers use butterflies" FMP Computer Services | 512-259-1190 | - xkcd http://www.fmp.com |
data:image/s3,"s3://crabby-images/9f085/9f085b5ee04e5f0d67360382f3d58e13e4a3107f" alt=""
Citando Lindsay Haisley <fmouse-mailman@fmp.com>:
Hi, when I try to send an e-mail to my list (only one recipient, the list itself), I get these: Aren't you creating a loop here? Why are you putting the list itself on the list as its only recipient? This appears to me to be an invitation for an endless loop.
-- Lindsay Haisley | "Real programmers use butterflies" FMP Computer Services | 512-259-1190 | - xkcd http://www.fmp.com |
Mailman-Users mailing list Mailman-Users@python.org http://mail.python.org/mailman/listinfo/mailman-users Mailman FAQ: http://wiki.list.org/x/AgA3 Security Policy: http://wiki.list.org/x/QIA9 Searchable Archives:
http://www.mail-archive.com/mailman-users%40python.org/Unsubscribe:
http://mail.python.org/mailman/options/mailman-users/rodrigoantunes%40pelota...
The list's e-mail obviously isn't a list member, what I said is that when you want to send and email to the list you put the list's email in the recipient.
data:image/s3,"s3://crabby-images/b96f7/b96f788b988da8930539f76bf56bada135c1ba88" alt=""
Rodrigo Abrantes Antunes writes:
Searching google I found that this error isn't related to the number of users in the list, it occurs because the total number of addresses in the To: and Cc: headers of the post equals or exceeds max_num_recipients.
The operational issues have already been addressed well in other posts. However the above statement is incorrect, and needs clarification.
The items visible in your personal mail client (MUA) in the To:, Cc:, and Bcc: fields are usually called "addresses" or "addressees". These are different from "recipients", which are the addresses that the host-to-host mail program (MTA) sends to. Mailman "explodes" the list's *address* into a large number of *recipients*, and asks the MTA to deliver to that whole list of recipients, or to chunks of it as Mark explains elsewhere. You will in general never see the list of recipients of a post unless you look at the MTA's logs.
By the way, there's nothing wrong with your understanding of plain English, in which "address" and "recipient" are pretty much the same. However, in technical discussion these words are often distinguished as above.
But in documentation is said that if this option is set to 0 it has no limit.
The limit you are running into here is not in Mailman, it is in the MTA. Mailman cannot tell the MTA what to do; it can only restrict itself to a small enough number that the MTA will cooperate with it.
data:image/s3,"s3://crabby-images/d8997/d8997862bf32685c4606ed1b7400f74ade85b899" alt=""
On Mon, 2012-10-22 at 13:46 -0200, Rodrigo Abrantes Antunes wrote:
Any ideas?
The behavior of Mailman with respect to the number of recipients specified in any single SMTP transaction is controlled by SMTP_MAX_RCPTS, which should be less than the max number of recipients allowed by the SMTP server for any single transaction. If your setting up this loop to stress-test your installation, set SMTP_MAX_RCPTS in mm_cfg.py to a small enough number to pass muster with the contas SMTP server.
-- Lindsay Haisley | "Humor will get you through times of no humor FMP Computer Services | better than no humor will get you through 512-259-1190 | times of humor." http://www.fmp.com | - Butch Hancock
data:image/s3,"s3://crabby-images/9f085/9f085b5ee04e5f0d67360382f3d58e13e4a3107f" alt=""
Citando Lindsay Haisley <fmouse-mailman@fmp.com>:
On Mon, 2012-10-22 at 13:46 -0200, Rodrigo Abrantes Antunes wrote:
Any ideas? The behavior of Mailman with respect to the number of recipients specified in any single SMTP transaction is controlled by SMTP_MAX_RCPTS, which should be less than the max number of recipients allowed by the SMTP server for any single transaction. If your setting up this loop to stress-test your installation, set SMTP_MAX_RCPTS in mm_cfg.py to a small enough number to pass muster with the contas SMTP server.
-- Lindsay Haisley | "Humor will get you through times of no humor FMP Computer Services | better than no humor will get you through 512-259-1190 | times of humor." http://www.fmp.com | - Butch Hancock
Mailman-Users mailing list Mailman-Users@python.org http://mail.python.org/mailman/listinfo/mailman-users Mailman FAQ: http://wiki.list.org/x/AgA3 Security Policy: http://wiki.list.org/x/QIA9 Searchable Archives:
http://www.mail-archive.com/mailman-users%40python.org/Unsubscribe:
http://mail.python.org/mailman/options/mailman-users/rodrigoantunes%40pelota...
I didn't set any loop, the list's e-mail obviously isn't a list member, what I said is that when you want to send and email to the list you put the list's email in the "To:" field and that's the only recipient when I'm sending e-mail, I'm not putting more recipients in "to:" field wich could burst the limit of max_num_recipients if this limit was set.
I've set SMTP_MAX_RCPTS to 250 in mailman and smtpd_recipient_limit to 300 in postfix and I'm still getting these errors.
data:image/s3,"s3://crabby-images/56955/56955022e6aae170f66577e20fb3ce4d8949255c" alt=""
On 10/23/2012 1:21 PM, Rodrigo Abrantes Antunes wrote:
I've set SMTP_MAX_RCPTS to 250 in mailman and smtpd_recipient_limit to 300 in postfix and I'm still getting these errors.
Did you restart Mailman after setting
SMTP_MAX_RCPTS = 250
in mm_cfg.py?
-- Mark Sapiro <mark@msapiro.net> The highway is for gamblers, San Francisco Bay Area, California better use your sense - B. Dylan
data:image/s3,"s3://crabby-images/d8997/d8997862bf32685c4606ed1b7400f74ade85b899" alt=""
On Tue, 2012-10-23 at 13:45 -0700, Mark Sapiro wrote:
On 10/23/2012 1:21 PM, Rodrigo Abrantes Antunes wrote:
I've set SMTP_MAX_RCPTS to 250 in mailman and smtpd_recipient_limit to 300 in postfix and I'm still getting these errors.
Did you restart Mailman
IMHO, a restart of postfix would probably be in order, too. I know that many settings in my mail server, courier MTA, require a restart of the server after changing them in order for them to take effect.
Mark, Brad, etc. I have a question here. Rodrigo says that in his Mailman smtp log, a SMTP transaction to contas for 828 recipients was "completed in 1.705 seconds"
Mailman also reports a _temporary_ failure of 450 addresses. Because this is a 4xx class error, can one assume that after accepting smtpd_recipient_limit "rcpt to" addresses, postfix started rejecting each new address with a 452 (4.5.3) error, and that Mailman continued to attempt to send recipients in spite of this? - after which Mailman sent, and postfix accepted, the body of the message?
This is the only scenario that makes any sense in light of the reported temporary failure. Is Mailman smart enough to pick up the thread on this and re-send to those addresses which were refused?
The only other possible scenario is that the SMTP server bounced the entire message after transmission of the message body was complete, based on an excessive number of recipients. In this case, wouldn't it make more sense for the mail server to return a 5xx (permanent) class error?
Inquiring minds want to know. I don't know postfix, and because all my outgoing lists have VERP personalization enabled, this problem never comes up here.
-- Lindsay Haisley | "We have met the enemy and he is us." FMP Computer Services | 512-259-1190 | -- Pogo http://www.fmp.com |
data:image/s3,"s3://crabby-images/aaf57/aaf572f6d110e3f5e181da5d1322a27383b2fd16" alt=""
- Lindsay Haisley <fmouse-mailman@fmp.com>:
IMHO, a restart of postfix would probably be in order, too. I know that many settings in my mail server, courier MTA, require a restart of the server after changing them in order for them to take effect.
postfix reload suffices.
-- Ralf Hildebrandt Charite Universitätsmedizin Berlin ralf.hildebrandt@charite.de Campus Benjamin Franklin http://www.charite.de Hindenburgdamm 30, 12203 Berlin Geschäftsbereich IT, Abt. Netzwerk fon: +49-30-450.570.155
data:image/s3,"s3://crabby-images/56955/56955022e6aae170f66577e20fb3ce4d8949255c" alt=""
Lindsay Haisley wrote:
Mark, Brad, etc. I have a question here. Rodrigo says that in his Mailman smtp log, a SMTP transaction to contas for 828 recipients was "completed in 1.705 seconds"
Mailman also reports a _temporary_ failure of 450 addresses. Because this is a 4xx class error, can one assume that after accepting smtpd_recipient_limit "rcpt to" addresses, postfix started rejecting each new address with a 452 (4.5.3) error, and that Mailman continued to attempt to send recipients in spite of this? - after which Mailman sent, and postfix accepted, the body of the message?
First of all, it is not clear how many recipients were sent in this SMTP transaction.
The 828 recipients was the entire list, but the list is chunked into pieces of *at most* SMTP_MAX_RCPTS (default 500) and each chunk is sent as a separate SMTP transaction. Further, the chunks ar separated by top level domain such that all .com addresses are in their (set of) chunks; all .net and .org addresses are in a separate set; all .edu, .us and .ca addresses, and the rest are in yet another set.
That notwithstanding, the actual SMTP transaction is handled by Python's smtplib module. The fact that there were no smtp-failure log messages that indicate an exception from smtplib (these would be log messages like 'All recipients refused: %s, msgid: %s', 'SMTP session failure: %s, %s, msgid: %s' or 'Low level smtp error: %s, msgid: %s') indicates that smtplib detected that at least one recipient was accepted and returned a dictionary, with one entry for each recipient that was refused. Each entry contains a tuple of the SMTP error code and the accompanying error message sent by the server. These are reported as indicated in the OP.
Mailman then records any permanent failures as bounces and if there are temporary failures as here, updates the recipient list for the message to contain only the temp failed addresses and queues it in the retry queue to be retried.
Thus, if the MTA is accepting say 50 recipients out of 500, the 500 will eventually all be delivered after about 10 times the retry interval which defaults to 15 minutes.
This is the only scenario that makes any sense in light of the reported temporary failure. Is Mailman smart enough to pick up the thread on this and re-send to those addresses which were refused?
See above.
The only other possible scenario is that the SMTP server bounced the entire message after transmission of the message body was complete, based on an excessive number of recipients. In this case, wouldn't it make more sense for the mail server to return a 5xx (permanent) class error?
That didn't happen here. If it had, the smtplib process would have thrown a smtplib.SMTPResponseException and this would have been logged with a 'SMTP session failure: %s, %s, msgid: %s' message.
-- Mark Sapiro <mark@msapiro.net> The highway is for gamblers, San Francisco Bay Area, California better use your sense - B. Dylan
data:image/s3,"s3://crabby-images/56955/56955022e6aae170f66577e20fb3ce4d8949255c" alt=""
Mark Sapiro wrote:
The 828 recipients was the entire list, but the list is chunked into pieces of *at most* SMTP_MAX_RCPTS (default 500) and each chunk is sent as a separate SMTP transaction. Further, the chunks ar separated by top level domain such that all .com addresses are in their (set of) chunks; all .net and .org addresses are in a separate set; all .edu, .us and .ca addresses, and the rest are in yet another set.
It's not really an important part of the answer, but the above paragraph should have said:
The 828 recipients was the entire list, but the list is chunked into pieces of *at most* SMTP_MAX_RCPTS (default 500) and each chunk is sent as a separate SMTP transaction. Further, the chunks are separated by top level domain such that all .com addresses are in their (set of) chunk(s); all .net and .org addresses are in a separate set; all .edu, .us and .ca addresses are in a third set, and the rest are in yet another set.
-- Mark Sapiro <mark@msapiro.net> The highway is for gamblers, San Francisco Bay Area, California better use your sense - B. Dylan
data:image/s3,"s3://crabby-images/d8997/d8997862bf32685c4606ed1b7400f74ade85b899" alt=""
On Tue, 2012-10-23 at 18:21 -0200, Rodrigo Abrantes Antunes wrote:
I didn't set any loop, the list's e-mail obviously isn't a list member, what I said is that when you want to send and email to the list you put the list's email in the "To:" field and that's the only recipient when I'm sending e-mail, I'm not putting more recipients in "to:" field wich could burst the limit of max_num_recipients if this limit was set.
OK, I'm sorry. I misunderstood.
I've set SMTP_MAX_RCPTS to 250 in mailman and smtpd_recipient_limit to 300 in postfix and I'm still getting these errors.
Did you restart Mailman and postfix? What do the Mailman log files show with regard to the number of recipients (smtp log) and the number of failures (post log) _after_ your changes and a restart of both postfix and Mailman? What's the total number of subscribers on the list (i.e. how many "rcpt to" addresses did Mailman _attempt_ to submit for posting)?
Do your mail system logs shed any light on anything? My mail logs are always my first stop when trying to debug a mail problem.
-- Lindsay Haisley | "Fighting against human creativity is like FMP Computer Services | trying to eradicate dandelions" 512-259-1190 | http://www.fmp.com | -- Pamela Jones
data:image/s3,"s3://crabby-images/56955/56955022e6aae170f66577e20fb3ce4d8949255c" alt=""
Rodrigo Abrantes Antunes wrote:
Hi, when I try to send an e-mail to my list (only one recipient, the list itself), I get these:
In mailman's smtp logs: Oct 22 13:26:17 2012 (22940) <xxxxxxx> smtp to contas for 828 recips, completed in 1.705 seconds
In mailman's post logs: Oct 22 13:26:17 2012 (22940) post to contas from xxx@xxxx, size=3620, message-id=<xxxxxxx>, 450 failures
In mailman's smtp-failure logs: Oct 22 13:26:17 2012 (22940) delivery to xxx@xxxxx failed with code 452: 4.5.3 Error: too many recipients
In my mm_cfg.py I have this: DEFAULT_MAX_NUM_RECIPIENTS = 0
The above setting has nothing to do with this. The message in your smtp-failure log comes from your MTA because Mailman is sending messages with a number of recipients (SMTP RCPT TO) greater than your MTA will accept.
In mm_cfg.py, set SMTP_MAX_RCPTS to a number less than the MTA's recipient limit, and restart Mailman.
-- Mark Sapiro <mark@msapiro.net> The highway is for gamblers, San Francisco Bay Area, California better use your sense - B. Dylan
participants (6)
-
Kalbfleisch, Gary
-
Lindsay Haisley
-
Mark Sapiro
-
Ralf Hildebrandt
-
Rodrigo Abrantes Antunes
-
Stephen J. Turnbull