2 домена 1 exim

EXIM, sendmail, postfix, Dovecot и прочие. Решение проблем связанных с работой электронной почты

Модератор: xM

Правила форума
Убедительная просьба юзать теги [code] при оформлении листингов.
Сообщения не оформленные должным образом имеют все шансы быть незамеченными.
Аватара пользователя
Agronom
сержант
Сообщения: 299
Зарегистрирован: 2006-12-11 10:30:13

2 домена 1 exim

Непрочитанное сообщение Agronom » 2007-12-19 13:39:21

Как можно сказать Exim, чтобы он принимал почту для двух доменов domain1.ru и domain2.ru, почтовые ящики разные?

Хостинговая компания Host-Food.ru
Хостинг HostFood.ru
 

Услуги хостинговой компании Host-Food.ru

Хостинг HostFood.ru

Тарифы на хостинг в России, от 12 рублей: https://www.host-food.ru/tariffs/hosting/
Тарифы на виртуальные сервера (VPS/VDS/KVM) в РФ, от 189 руб.: https://www.host-food.ru/tariffs/virtualny-server-vps/
Выделенные сервера, Россия, Москва, от 2000 рублей (HP Proliant G5, Intel Xeon E5430 (2.66GHz, Quad-Core, 12Mb), 8Gb RAM, 2x300Gb SAS HDD, P400i, 512Mb, BBU):
https://www.host-food.ru/tariffs/vydelennyi-server-ds/
Недорогие домены в популярных зонах: https://www.host-food.ru/domains/

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35288
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: 2 домена 1 exim

Непрочитанное сообщение Alex Keda » 2007-12-19 13:40:39

ответ - почти всегда - ДА
=========
однако задачу чётче ставь.
Убей их всех! Бог потом рассортирует...

Аватара пользователя
Agronom
сержант
Сообщения: 299
Зарегистрирован: 2006-12-11 10:30:13

Re: 2 домена 1 exim

Непрочитанное сообщение Agronom » 2007-12-19 14:01:39

есть Exim, настроенный на прием почты для домена domain1.ru с почтовыми ящиками user1, user2 .... user5, у каждого юзера своя папка /home/user1 и т.д. Нужно добавить прием почты для ещё одного домена domain2.ru, для юзеров 2user1, 2user2.....2user5 с папками /home/2user1 и т.д. но так, чтобы почта приходила и для user1@domain.ru и для 2user@domain2.ru - старая осталась, а новая добавилась
P.S. и без использования мускуля

Аватара пользователя
Agronom
сержант
Сообщения: 299
Зарегистрирован: 2006-12-11 10:30:13

Re: 2 домена 1 exim

Непрочитанное сообщение Agronom » 2007-12-19 14:32:01

multi_domain (Когда эта опция установлена, транспорт “smtp” может обрабатывать множество адресов, содержащих смесь различных доменов, если все они резольвятся в один и тот же список хостов. Выключение опции ограничивает транспорт обработкой лишь одного домена одновременно. Это полезно, если вы хотите использовать “$domain” в раскрытии для транспотра, поскольку она установлена лишь когда один домен вовлечён в удалённую доставку.) - это то что нужно?

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35288
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: 2 домена 1 exim

Непрочитанное сообщение Alex Keda » 2007-12-19 14:44:41

придётся держать текстовый файл с соотетствием иём и хомяков, а вообще - почему бы и нет.
Убей их всех! Бог потом рассортирует...

Аватара пользователя
Agronom
сержант
Сообщения: 299
Зарегистрирован: 2006-12-11 10:30:13

Re: 2 домена 1 exim

Непрочитанное сообщение Agronom » 2007-12-19 15:00:29

lissyara писал(а):придётся держать текстовый файл с соотетствием иём и хомяков, а вообще - почему бы и нет.
пользователей всего-то 5 человек, так что файлик можно создать, но мне непонятно что нужно прописать в exim.conf чтобы принимал почту для второго домена?

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35288
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: 2 домена 1 exim

Непрочитанное сообщение Alex Keda » 2007-12-19 15:13:57

внести второй в список локалдоменов
Убей их всех! Бог потом рассортирует...

shadowbv
проходил мимо

Re: 2 домена 1 exim

Непрочитанное сообщение shadowbv » 2011-03-15 20:42:08

А как можно сказать Exim, чтобы он принимал почту для двух доменов domain1.org и domain2.com ящики одинаковые?

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35288
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: 2 домена 1 exim

Непрочитанное сообщение Alex Keda » 2011-03-18 15:01:24

роутером
Убей их всех! Бог потом рассортирует...

shadowbv
проходил мимо

Re: 2 домена 1 exim

Непрочитанное сообщение shadowbv » 2011-03-18 23:50:34

спасибо, смешно...........
сам разобрался, только все на сендмейле сделал......

Аватара пользователя
Alex Keda
стреляли...
Сообщения: 35288
Зарегистрирован: 2004-10-18 14:25:19
Откуда: Made in USSR
Контактная информация:

Re: 2 домена 1 exim

Непрочитанное сообщение Alex Keda » 2011-03-20 19:16:51

действительно смешно.
если человек документацию читать не хочет а в админы подался
Убей их всех! Бог потом рассортирует...

DFPall
проходил мимо
Сообщения: 2
Зарегистрирован: 2011-03-22 13:34:13
Откуда: Киев

Re: 2 домена 1 exim

Непрочитанное сообщение DFPall » 2011-03-22 14:00:41

Собственно неохота создавать тему с похожим названием.

Было:
домен: proba.com.ua
днс: mx mail.proba.com.ua
почтовый сервер: FreeBSD 6.2-RELEASE, настроен по статье:http://www.lissyara.su/articles/freebsd ... tfixadmin/, единственно изменения в кол-ве таблиц мускуля, структуре и их названии (aliases, domains, userforward, users)
все отлично работает.

Необходимо добавить на этом же сервере:
домен: test.com

1. добавляю в днс запись mx mail.proba.com.ua (дабы не мучатся с роутами)
2. в таблице мускуля domains - добавляю test.com local
3. в таблицу users - пользователя my@test.com

результат:

Код: Выделить всё

2011-03-22 12:17:58 H=mail-qy0-f172.google.com [209.85.216.172] F=<my@gmail.com> rejected RCPT <my@test.com>: relay not permitted
конфиг exima:

Код: Выделить всё

primary_hostname = mail.proba.com.ua
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.5.0/24 
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_parents \
        +lost_incoming_connection \
        +received_sender \
        +received_recipients \
        +smtp_confirmation \
        +smtp_syntax_error \
        +smtp_protocol_error \
        -queue_run
syslog_timestamp = no
acl_smtp_rcpt = acl_check_rcpt
acl_smtp_mime = acl_check_mime
acl_smtp_data = acl_check_content
av_scanner = clamd:/var/run/clamav/clamd.sock
qualify_domain = proba.com.ua
qualify_recipient = proba.com.ua
allow_domain_literals = false
never_users = root
host_lookup = *
rfc1413_hosts = *
rfc1413_query_timeout = 2s
ignore_bounce_errors_after = 30m 
timeout_frozen_after = 3d
freeze_tell = postmaster@proba.com.ua
smtp_accept_max = 250
smtp_accept_max_per_connection = 100
smtp_accept_max_per_host = 20
split_spool_directory = true
remote_max_parallel = 50
return_size_limit = 25k
message_size_limit = 100M
helo_allow_chars = _
smtp_enforce_sync = true
smtp_banner = "Welcome on our mail server!"

hide mysql_servers = localhost/exim/exim/password

######################################################################
#                       ACL ONFIGURATION                            #
#         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}}

  accept  authenticated = *

  deny    message       = Your IP in HELO - access denied!
          hosts         =  * : !+relay_from_hosts 
          condition     = ${if eq{$sender_helo_name}\
                          {$sender_host_address}{true}{false}}

  deny    condition     = ${if eq{$sender_helo_name}\
                          {$interface_address}{yes}{no}}
          hosts         = !127.0.0.1 : !localhost : *
          message       = Main IP in your HELO! Access denied!


  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    condition     = ${if match{$sender_helo_name}\
                           {\N^\d+$\N}{yes}{no}}
          hosts         = !127.0.0.1 : !localhost : *
          message       = Can not be only number in HELO!


  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 \
  is in a black list at $dnslist_domain\n$dnslist_text
          log_message   = found in $dnslist_domain
          dnslists      = dialups.mail-abuse.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

  warn
        set acl_m0 = 7s
  warn
        hosts = +relay_from_hosts
        set acl_m0 = 0s
  warn
        delay = $acl_m0


  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

  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/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

# End of Exim configuration file
где я что пропустил, покажите куда рыть и если можно то пример конфигурации под 2 и более доменов на 1 серве??
Последний раз редактировалось Laa 2011-03-23 7:25:56, всего редактировалось 1 раз.
Причина: Убедительная просьба юзать теги [code] при оформлении листингов.

Аватара пользователя
Laa
ст. лейтенант
Сообщения: 1032
Зарегистрирован: 2008-02-21 18:25:33
Откуда: Украина, Россия

Re: 2 домена 1 exim

Непрочитанное сообщение Laa » 2011-03-23 7:27:44

Разобраться самому с:

1. domainlist local_domains ...
2. virtual_localuser: .... domains = ... local_parts = ....

И станет все ясно.
exim: помните, что выдавая deny, вы можете недоставить ваше же письмо, зарубив sender-verify удаленного MTA к вашему MTA!!!

shadowbv
проходил мимо

Re: 2 домена 1 exim

Непрочитанное сообщение shadowbv » 2011-03-25 22:31:43

Alex Keda писал(а):действительно смешно.
если человек документацию читать не хочет а в админы подался
читать не проблема, можна же подсказать в каком нарправлении рыть..... возможно на такие ничтожные вопросы большие гуру отвечать не могут это ниже их достоинства?

Alteron
сержант
Сообщения: 230
Зарегистрирован: 2008-07-21 9:35:11

Re: 2 домена 1 exim

Непрочитанное сообщение Alteron » 2011-04-06 19:16:02

shadowbv писал(а):
Alex Keda писал(а):действительно смешно.
если человек документацию читать не хочет а в админы подался
читать не проблема, можна же подсказать в каком нарправлении рыть.....
Как понять - в каком направлении рыть?... Дык, проверять работу. Кто откуда знает, какие у тебя там таблицы нах####рчены и чо у тебя там SQL на твои запросы отдаёт.
По-моему, достаточно ясно ткнули в два конкретных места.
Измеритель верёвочками.