The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

форумы  помощь  поиск  регистрация  майллист  ВХОД  слежка  RSS
"Exim 2 вопроса - отправка почты"
Вариант для распечатки  
Пред. тема | След. тема 
Форумы OpenNET: Виртуальная конференция (Public)
Изначальное сообщение [Проследить за развитием треда]

"Exim 2 вопроса - отправка почты"  
Сообщение от Frei email(ok) on 09-Фев-07, 16:12 
Добрый день.

В корпоративной сети на сервере стоит Exim. Через него происходит отправка почты и приём.

Помогите пожалуйста решить следующие две проблемы:

1. Очень долго происходит отправка почты от клиента в локальной сети на сервер smtp.
Запустив exim вот так "exim -bd -d+all" вижу

15:52:07  9128                 = no
15:52:07  9128 deny: condition test failed
15:52:07  9128 processing "deny"
15:52:07  9128 check dnslists = relays.ordb.org
15:52:07  9128 DNS list check: relays.ordb.org
15:52:07  9128 new DNS lookup for 11.1.168.192.relays.ordb.org
;; res_querydomain(11.1.168.192.relays.ordb.org, <Nil>, 1, 1)
;; res_query(11.1.168.192.relays.ordb.org, 1, 1)
;; res_mkquery(0, 11.1.168.192.relays.ordb.org, 1, 1)
;; res_send()
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 45033
;; flags: rd; QUERY: 1, ANSWER: 0, AUTHORITY: 0, ADDITIONAL: 0
;;      11.1.168.192.relays.ordb.org, type = A, class = IN
;; Querying server (# 1) address = 81.211.111.211
;; timeout
;; Querying server (# 2) address = 195.218.227.227
;; timeout
;; Querying server (# 2) address = 195.218.227.227
;; timeout
;; Querying server (# 1) address = 81.211.111.211
;; timeout
;; Querying server (# 1) address = 81.211.111.211
;; timeout
;; Querying server (# 2) address = 195.218.227.227
;; timeout
;; Querying server (# 2) address = 195.218.227.227
;; timeout
;; Querying server (# 1) address = 81.211.111.211
server rejected query:
;; ->>HEADER<<- opcode: QUERY, status: SERVFAIL, id: 30261
;; flags: qr rd ra; QUERY: 1, ANSWER: 0, AUTHORITY: 0, ADDITIONAL: 0
;;      52.100.113.62.relays.ordb.org, type = A, class = IN
;; Querying server (# 1) address = 81.211.111.211

Вот как раз на этом куске процес приёма сообщения на smtp сервере и тормозится.

Почему это так? и как исправить?

2. Проблема №2
На один из серверов в интернете не передаётся почта. На все передаётся, а на этот нет. Разговаривал с его администратором говорит, что его сервак проверяет не "свои" домены при приёмке почты и делает запрос на к моему серваку на предмет проверки существования отправителя. Мой же сервак в течении 30 секунд не даёт ответа из за этого письма тот сервак не принимается. Проясните пожалуйста в чём беда, как исправить?

Если необходимо могу вывести сюда свой конфиг.

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

 Оглавление

Сообщения по теме [Сортировка по времени, UBB]


1. "Exim 2 вопроса - отправка почты"  
Сообщение от gibbon email(??) on 09-Фев-07, 16:36 
>Добрый день.
>
>В корпоративной сети на сервере стоит Exim. Через него происходит отправка почты
>и приём.
>
>Помогите пожалуйста решить следующие две проблемы:
>
>1. Очень долго происходит отправка почты от клиента в локальной сети на
>сервер smtp.
>Запустив exim вот так "exim -bd -d+all" вижу
>
>15:52:07  9128          
>       = no
>15:52:07  9128 deny: condition test failed
>15:52:07  9128 processing "deny"
>15:52:07  9128 check dnslists = relays.ordb.org
>15:52:07  9128 DNS list check: relays.ordb.org
>15:52:07  9128 new DNS lookup for 11.1.168.192.relays.ordb.org
>;; res_querydomain(11.1.168.192.relays.ordb.org, <Nil>, 1, 1)
>;; res_query(11.1.168.192.relays.ordb.org, 1, 1)
>;; res_mkquery(0, 11.1.168.192.relays.ordb.org, 1, 1)
>;; res_send()
>;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 45033
>;; flags: rd; QUERY: 1, ANSWER: 0, AUTHORITY: 0, ADDITIONAL: 0
>;;      11.1.168.192.relays.ordb.org, type = A, class =
>IN
>;; Querying server (# 1) address = 81.211.111.211
>;; timeout
>;; Querying server (# 2) address = 195.218.227.227
>;; timeout
>;; Querying server (# 2) address = 195.218.227.227
>;; timeout
>;; Querying server (# 1) address = 81.211.111.211
>;; timeout
>;; Querying server (# 1) address = 81.211.111.211
>;; timeout
>;; Querying server (# 2) address = 195.218.227.227
>;; timeout
>;; Querying server (# 2) address = 195.218.227.227
>;; timeout
>;; Querying server (# 1) address = 81.211.111.211
>server rejected query:
>;; ->>HEADER<<- opcode: QUERY, status: SERVFAIL, id: 30261
>;; flags: qr rd ra; QUERY: 1, ANSWER: 0, AUTHORITY: 0, ADDITIONAL:
>0
>;;      52.100.113.62.relays.ordb.org, type = A, class =
>IN
>;; Querying server (# 1) address = 81.211.111.211
>
>Вот как раз на этом куске процес приёма сообщения на smtp сервере
>и тормозится.
>
>Почему это так? и как исправить?

Убрать проверку в relays.ordb.org, насколько я знаю они уже закрылись

>
>2. Проблема №2
>На один из серверов в интернете не передаётся почта. На все передаётся,
>а на этот нет. Разговаривал с его администратором говорит, что его
>сервак проверяет не "свои" домены при приёмке почты и делает запрос
>на к моему серваку на предмет проверки существования отправителя. Мой же
>сервак в течении 30 секунд не даёт ответа из за этого
>письма тот сервак не принимается. Проясните пожалуйста в чём беда, как
>исправить?
>
Несколько вариантов:
1. На вашем сервере используется delay в ACL и он сам делает задержку
2. Долгий процесс reverse dns lookup
3. Долгий процесс ident

>Если необходимо могу вывести сюда свой конфиг.

это было бы неплохо

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

2. "Exim 2 вопроса - отправка почты"  
Сообщение от gibbon email(??) on 09-Фев-07, 16:40 
И еще, возможно проблема только relays.ordb.org
Очень долго осуществляется проверка по несуществующему blacklistу

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

5. "Exim 2 вопроса - отправка почты"  
Сообщение от billybons2006 email(ok) on 09-Фев-07, 16:57 
В дополнение к gibbon хочу сказать, что, возможно, вам вообще имеет смысл отменить всякие проверки DNS? По крайней мере, при настройке почтового сервера sendmail я не раз сталкивался с этим и это помогало. Не могу точно сказать, где это меняется в Exim, но суть мысля у меня такая :)
Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

3. "Exim 2 вопроса - отправка почты"  
Сообщение от Frei email(ok) on 09-Фев-07, 16:45 
Вот конфиг:

primary_hostname = domain.ru
domainlist local_domains = ${lookup mysql{SELECT domain FROM domains \
                        WHERE domain='${domain}' AND \
                        (type='LOCAL' OR type='VIRTUAL')}}

domainlist relay_to_domains = ${lookup mysql{SELECT domain FROM domains \
                        WHERE domain='${domain}' AND type='RELAY'}}

hostlist relay_from_hosts = 127.0.0.1 : 192.168.0.0/16
auth_advertise_hosts = *
daemon_smtp_ports = 25 : 465
tls_on_connect_ports = 465
tls_advertise_hosts = *
tls_certificate = /etc/ssl/certs/mail.pem
tls_privatekey = /etc/ssl/certs/mail.pem

log_selector = +all

acl_smtp_rcpt = acl_check_rcpt
acl_smtp_mime = acl_check_mime
qualify_domain = domain.ru
allow_domain_literals = false
never_users = root
host_lookup = *
rfc1413_hosts = *
rfc1413_query_timeout = 0s
ignore_bounce_errors_after = 30m
timeout_frozen_after = 3d
freeze_tell = postmaster
message_size_limit = 10M
smtp_accept_max = 100
smtp_accept_max_per_connection = 5
smtp_accept_max_per_host = 2
split_spool_directory = true
remote_max_parallel = 15
smtp_banner = "Welcome on our mail server!\n\
    This system does not accept Unsolicited \
    Commercial Email\nand will blacklist \
    offenders via our spam processor.\nHave a \
    nice day!\n\n${primary_hostname} ESMTP"

hide mysql_servers = localhost/exim/exim/password

######################################################################
#                       ACL CONFIGURATION                            #
#         Specifies access control lists for incoming SMTP mail      #
######################################################################
begin acl

acl_check_rcpt:

  accept  hosts = :

  deny    domains       = +local_domains
          local_parts   = ^[.] : ^.*[@%!/|]

  deny    domains       = !+local_domains
          local_parts   = ^[./|] : ^.*[@%!] : ^.*/\\.\\./

  accept  local_parts   = postmaster
          domains       = +local_domains

  require verify        = sender

  deny    message       = HELO/EHLO required by SMTP RFC
          condition     = ${if eq{$sender_helo_name}{}{yes}{no}}

  deny    message       = Go Away! You are spammer.
          condition     = ${if match{$sender_host_name} \
                          {bezeqint\\.net|net\\.il|dialup|dsl|pool|peer|dhcp} \
                          {yes}{no}}

  deny    message       = rejected because \
  $sender_host_address is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = relays.ordb.org
  deny    message       = message from \
  $sender_host_address rejected - see http://njabl.org/
          log_message   = found in $dnslist_domain
          dnslists      = dnsbl.njabl.org
  deny    message       = rejected because \
  $sender_host_address for bad WHOIS info, see http://www.rfc-ignorant.org/
          log_message   = found in $dnslist_domain
          dnslists      = ipwhois.rfc-ignorant.org
  deny    message       = rejected because $sender_host_address \
  is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = dialups.mail-abuse.org
  deny    message       = rejected because $sender_host_address \
  is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = list.dsbl.org
  deny    message       = Spam blocked see: \
  http://www.spamcop.net/w3m?action=checkblock&ip=$sender_host_address
          log_message   = found in $dnslist_domain
          dnslists      = bl.spamcop.net
  deny    message       = rejected, $sender_host_address \
  Open Proxy, see: $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = dnsbl.void.ru

  accept  domains       = +local_domains
          endpass
          message       = unknown user
          verify        = recipient

  accept  domains       = +relay_to_domains
          endpass
          message       = unrouteable address
          verify        = recipient

  accept  hosts         = +relay_from_hosts
  accept  authenticated = *
  deny    message       = relay not permitted

acl_check_mime:

  warn decode = default

  deny message = Blacklisted file extension detected ($mime_filename)
       condition = ${if match \
                    {${lc:$mime_filename}} \
                    {\N(\.exe|\.pif|\.bat|\.scr|\.lnk|\.com|\.vbs|\.cpl)$\N} \
                    {1}{0}}

  deny message = Sorry, noone speaks chinese here
       condition = ${if eq{$mime_charset}{gb2312}{1}{0}}

accept

######################################################################
#                      ROUTERS CONFIGURATION                         #
#               Specifies how addresses are handled                  #
######################################################################
#     THE ORDER IN WHICH THE ROUTERS ARE DEFINED IS IMPORTANT!       #
# An address is passed to each router in turn until it is accepted.  #
######################################################################

begin routers

dnslookup:
  driver = dnslookup
  domains = ! +local_domains
  transport = remote_smtp
  ignore_target_hosts = 0.0.0.0 : 127.0.0.0/8
  no_more

system_aliases:
  driver = redirect
  allow_fail
  allow_defer
  data = ${lookup mysql{SELECT recipients FROM aliases \
         WHERE local_part='${local_part}' AND domain='${domain}'}}

userforward:
  driver = redirect
  allow_fail
  allow_defer
  data = ${lookup mysql{SELECT recipients FROM userforward \
         WHERE local_part='${local_part}' AND domain='${domain}'}}

virtual_localuser:
  driver = accept
  domains = ${lookup mysql{SELECT domain from domains WHERE domain='${domain}'}}
  local_parts = ${lookup mysql{SELECT login from users \
                WHERE login='${local_part}' AND domain='${domain}'}}
  transport = local_delivery

######################################################################
#                      TRANSPORTS CONFIGURATION                      #
######################################################################
#                       ORDER DOES NOT MATTER                        #
#     Only one appropriate transport is called for each delivery.    #
######################################################################

begin transports

remote_smtp:
  driver = smtp

local_delivery:
  driver = appendfile
  check_string = ""
  create_directory
  delivery_date_add
  directory = /usr/home/services/mail/$domain/$local_part
  directory_mode = 770
  envelope_to_add
  group = mail
  maildir_format
  maildir_tag = ,S=$message_size
  message_prefix = ""
  message_suffix = ""
  mode = 0660
  quota = ${lookup mysql{SELECT quota FROM users \
          WHERE login='${local_part}' AND domain='${domain}'}{${value}M}}
  quota_size_regex = S=(\d+)$
  quota_warn_threshold = 75%
  return_path_add

address_pipe:
  driver = pipe
  return_output

address_file:
  driver = appendfile
  delivery_date_add
  envelope_to_add
  return_path_add

address_reply:
  driver = autoreply

######################################################################
#                      RETRY CONFIGURATION                           #
######################################################################

begin retry

*                      quota
*                      *           F,2h,15m; G,16h,1h,1.5; F,4d,6h


######################################################################
#                      REWRITE CONFIGURATION                         #
######################################################################

begin rewrite

######################################################################
#                   AUTHENTICATION CONFIGURATION                     #
######################################################################

begin authenticators

auth_plain:
  driver = plaintext
  public_name = PLAIN
  server_condition = ${lookup mysql{SELECT login FROM users \
                        WHERE login = '${quote_mysql:${local_part:$2}}' \
                        AND domain = '${quote_mysql:${domain:$2}}' \
                        AND decrypt = '${quote_mysql:$3}' \
                        AND status = '1'}{yes}{no}}
  server_prompts = :
server_set_id = $2

auth_login:
  driver = plaintext
  public_name = LOGIN
  server_condition = ${lookup mysql{SELECT login FROM users \
                        WHERE login = '${quote_mysql:${local_part:$1}}' \
                        AND domain = '${quote_mysql:${domain:$1}}' \
                        AND decrypt = '${quote_mysql:$2}' \
                        AND status = '1'}{yes}{no}}
  server_prompts = Username:: : Password::
server_set_id = $1

auth_cram_md5:
  driver = cram_md5
  public_name = CRAM-MD5
  server_secret = ${lookup mysql{SELECT decrypt FROM users \
                        WHERE login = '${quote_mysql:${local_part:$1}}' \
                        AND domain = '${quote_mysql:${domain:$1}}' \
                        AND status = '1'}{$value}fail}
server_set_id = $1

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

4. "Exim 2 вопроса - отправка почты"  
Сообщение от Frei email(ok) on 09-Фев-07, 16:50 
Если я правильно понимаю (как же я раньше не подумал :) ) чтобы уменьшить ожидание нужно удальить кусок:

deny    message       = rejected because \
$sender_host_address is in a black list at $dnslist_domain\n$dnslist_text
log_message   = found in $dnslist_domain
dnslists      = relays.ordb.org

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

6. "Exim 2 вопроса - отправка почты"  
Сообщение от Frei email(ok) on 09-Фев-07, 17:43 
Закоментировал вот это, и теперь всё работает

deny    message       = rejected because \
  $sender_host_address is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = relays.ordb.org
  deny    message       = message from \
  $sender_host_address rejected - see http://njabl.org/
          log_message   = found in $dnslist_domain
          dnslists      = dnsbl.njabl.org
  deny    message       = rejected because \
  $sender_host_address for bad WHOIS info, see http://www.rfc-ignorant.org/
          log_message   = found in $dnslist_domain
          dnslists      = ipwhois.rfc-ignorant.org
  deny    message       = rejected because $sender_host_address \
  is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = dialups.mail-abuse.org
  deny    message       = rejected because $sender_host_address \
  is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = list.dsbl.org
  deny    message       = Spam blocked see: \
  http://www.spamcop.net/w3m?action=checkblock&ip=$sender_host_address
          log_message   = found in $dnslist_domain
          dnslists      = bl.spamcop.net
  deny    message       = rejected, $sender_host_address \
  Open Proxy, see: $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = dnsbl.void.ru

Высказать мнение | Ответить | Правка | Наверх | Cообщить модератору

Архив | Удалить

Индекс форумов | Темы | Пред. тема | След. тема
Оцените тред (1=ужас, 5=супер)? [ 1 | 2 | 3 | 4 | 5 ] [Рекомендовать для помещения в FAQ]




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру