В Postfix 2.10.2 у меня есть установка с несколькими доменами и несколькими виртуальными псевдонимами для назначения почтовых адресов локальным пользователям. Он отлично работает, пока я не добавляю кучу.
До того, как я использовал виртуальные псевдонимы, у меня был общий список с
local_recipient_maps =
luser_relay = catchall
но поскольку мне нужно отсортировать почтовые адреса из разных доменов, мне пришлось использовать виртуальные псевдонимы.
Сейчас postfix.org говорит, что я должен сделать это вот так, что я и сделал:
/etc/postfix/main.cf:
virtual_alias_domains = example.com
virtual_alias_maps = hash:/etc/postfix/virtual
/ и т.д. / постфикс / виртуальный:
postmaster@example.com account1
info@example.com account1
sales@example.com account2
@example.com catchall
Но если я это сделаю, общий адрес захватит всю мою почту, а не только почту на явно не определенные адреса. Почему это так и как мне это изменить?
Я сделал виртуальную почтовую карту и перезапустил Postfix. В журнале нет ошибок, просто регистрируется доставка на общий адрес. И есть предупреждение «не указывайте домен example.com в ОБЕИХ mydestination и virtual_alias_domains», но я этого не делал! У меня даже нет директивы о моем назначении. (Он есть в конфигурации ниже, но я добавил это после того, как так предложил NickW.)
Вот мой полный конф:
alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
broken_sasl_auth_clients = yes
config_directory = /etc/postfix
home_mailbox = Maildir/
inet_interfaces = all
inet_protocols = all
mailbox_command = /usr/lib/dovecot/deliver -c /etc/dovecot/dovecot.conf -m "${EXTENSION}"
mailbox_size_limit = 0
mydestination = $myhostname
myhostname = mydomain.com
mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
myorigin = /etc/mailname
readme_directory = no
recipient_delimiter = +
relayhost =
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
smtp_use_tls = yes
smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)
smtpd_recipient_restrictions = reject_unknown_sender_domain, reject_unknown_recipient_domain, reject_unauth_pipelining, permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination
smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_authenticated_header = yes
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_path = private/dovecot-auth
smtpd_sasl_security_options = noanonymous
smtpd_sasl_type = dovecot
smtpd_sender_restrictions = reject_unknown_sender_domain
smtpd_tls_auth_only = yes
smtpd_tls_cert_file = /etc/dovecot/dovecot.pem
smtpd_tls_key_file = /etc/dovecot/private/dovecot.pem
smtpd_tls_mandatory_ciphers = medium
smtpd_tls_mandatory_protocols = SSLv3, TLSv1
smtpd_tls_received_header = yes
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
smtpd_use_tls = yes
tls_random_source = dev:/dev/urandom
virtual_alias_domains = $myhostname, myotherdomain.com
virtual_alias_maps = hash:/etc/postfix/virtual
Если вы включите перехват всех адресов электронной почты в виртуальный псевдоним, он будет работать.
в main.cf
:
virtual_alias_maps = hash:/etc/postfix/virtual
в virtual
:
user1@example.com user1@example.com
user2@example.com user2@example.com
...
catchall@example.com catchall@example.com
@example.com catchall@example.com
Итак, я разобрался. Некоторые люди предполагают, что всеохватывающая информация должна находиться поверх файла виртуального псевдонима, но я пробовал это раньше, и это не помогло (хотя я нашел это решение вполне логичным).
Что сработало:
mydestination=localhost
(это не $myhostname
)@domain.com catchall-account@localhost
contact@domain.com contact@localhost
В этом примере предполагается, что у вас есть пользователи UNIX с именем catchall-account
и contact
. Письма на адрес contact@domain.com будут доставлены контактному пользователю, а вся остальная почта будет доставлена в учетную запись для приема всей почты домена.
Возможно, это не обязательно во всех случаях, но в моем частном случае я хочу использовать учетную запись для сохранения почты для некоторых адресов, но почта, отправленная непосредственно на эту учетную запись, должна попадать во все.
В конце концов, похоже, что Postfix не работает через виртуальные псевдонимы сверху вниз, и, кроме того, у всех есть особый приоритет. Я буду рад дальнейшим комментариям, если кто-то действительно сможет объяснить такое поведение.
Попробуйте настроить свой mydestination = $myhostname
и убедитесь, что ваше имя хоста настроено в main.cf, например, myhostname = mail.example.com
.