Trong Postfix 2.10.2, tôi có một thiết lập với nhiều tên miền và một số bí danh ảo để gán địa chỉ thư cho người dùng cục bộ. Nó hoạt động tốt miễn là tôi không thêm một cái bẫy.
Trước khi tôi sử dụng các bí danh ảo, tôi đã xác định rõ
local_recipient_maps =
luser_relay = catchall
nhưng vì tôi cần sắp xếp các địa chỉ thư từ các miền khác nhau, tôi phải sử dụng các bí danh ảo.
Bây giờ postfix.org nói rằng tôi nên làm như thế này, điều mà tôi đã làm:
/etc/postfix/main.cf:
virtual_alias_domains = example.com
virtual_alias_maps = hash:/etc/postfix/virtual
/ etc / postfix / ảo:
postmaster@example.com account1
info@example.com account1
sales@example.com account2
@example.com catchall
Nhưng nếu tôi làm như vậy, địa chỉ Catchall lấy tất cả thư của tôi thay vì chỉ thư đến địa chỉ không được xác định rõ ràng. Tại sao lại như vậy và làm thế nào để tôi thay đổi nó?
Tôi đã làm postmap ảo và cũng khởi động lại Postfix. Không có lỗi trong nhật ký, nó chỉ ghi nhật ký giao hàng đến địa chỉ Catchall. Và có một cảnh báo "không liệt kê domain example.com trong BOTH mydestination và virtual_alias_domains", nhưng tôi đã không làm điều đó! Tôi thậm chí không có một chỉ thị mydestination. (Có một cấu hình bên dưới, nhưng tôi đã thêm rằng sau khi NickW đề xuất như vậy.)
Đây là conf hoàn chỉnh của tôi:
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