![](/img/trans.png)
[英](postfix + dovecot + noIP) 554 5.7.1 - Relay access denied
[英]Linux postfix/dovecot 554 Relay access denied
嘗試從Outlook客戶端發送電子郵件時,我遇到此錯誤554 Relay access denied
。
我可以閱讀傳入的郵件,但無法發送。
如果我使用telnet localhost 25可以連接外部電子郵件,但是使用Outlook Client則無法使用。
這是我的postfix和dovecot配置:
postconf -n
alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
config_directory = /etc/postfix
inet_interfaces = all
mailbox_size_limit = 0
mydestination = localhost
myhostname = mail.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 =
smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)
smtpd_recipient_restrictions = permit_sasl_authenticated, permit_mynetworks, reject_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_path = private/auth
smtpd_sasl_type = dovecot
smtpd_tls_auth_only = yes
smtpd_tls_cert_file = /etc/ssl/certs/dovecot.pem
smtpd_tls_key_file = /etc/ssl/private/dovecot.pem
smtpd_use_tls = yes
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual-alias-maps.cf
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual-mailbox-domains.cf
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual-mailbox-maps.cf
virtual_transport = lmtp:unix:private/dovecot-lmtp
doveconf -n
# 2.1.7: /etc/dovecot/dovecot.conf
# OS: Linux 3.9.3-x86_64-linode33 x86_64 Ubuntu 13.04 ext3
auth_mechanisms = plain login
mail_location = maildir:/var/mail/vhosts/%d/%n
mail_privileged_group = mail
namespace inbox {
inbox = yes
location =
mailbox Drafts {
special_use = \Drafts
}
mailbox Junk {
special_use = \Junk
}
mailbox Sent {
special_use = \Sent
}
mailbox "Sent Messages" {
special_use = \Sent
}
mailbox Trash {
special_use = \Trash
}
prefix =
}
passdb {
args = /etc/dovecot/dovecot-sql.conf.ext
driver = sql
}
passdb {
args = /etc/dovecot/dovecot-sql.conf.ext
driver = sql
}
protocols = imap pop3 lmtp
service auth-worker {
user = vmail
}
service auth {
unix_listener /var/spool/postfix/private/auth {
group = postfix
mode = 0666
user = postfix
}
unix_listener auth-userdb {
mode = 0600
user = vmail
}
user = dovecot
}
service imap-login {
inet_listener imap {
port = 0
}
}
service lmtp {
unix_listener /var/spool/postfix/private/dovecot-lmtp {
group = postfix
mode = 0600
user = postfix
}
}
service pop3-login {
inet_listener pop3 {
port = 0
}
}
ssl = required
ssl_cert = </etc/dovecot/dovecot.pem
ssl_key = </etc/dovecot/private/dovecot.pem
userdb {
args = uid=vmail gid=vmail home=/var/mail/vhosts/%d/%n
driver = static
}
userdb {
args = uid=vmail gid=vmail home=/var/mail/vhosts/%d/%n
driver = static
}
有什么想法嗎?
如果您使用后綴版本更新則2.10,那么你需要添加smtpd_relay_restrictions
選項描述在這里 :
\n #在Postfix 2.10及更高版本中,郵件中繼策略為\n #最好在smtpd_relay_restrictions下指定。\n /etc/postfix/main.cf:\n smtpd_relay_restrictions =\n permit_mynetworks\n permit_sasl_authenticated\n reject_unauth_destination\n\n #較舊的配置將中繼控制和垃圾郵件控制結合在一起\n #smtpd_recipient_restrictions。 將此示例與Postfix≥一起使用\n #2.10指定“ smtpd_relay_restrictions =“。\n /etc/postfix/main.cf:\n smtpd_recipient_restrictions =\n permit_mynetworks\n permit_sasl_authenticated\n reject_unauth_destination\n 其他規則\n
之后,任何經過sasl身份驗證的用戶都應該能夠使用smtp通過服務器發送郵件。
對於我在Amazon AWS EC2上的Postfix 2.6.6,事實證明我在main.cf中配置了“ mydestination”和“ relay_domains”設置錯誤。 正確的值(對我有用的值)是:
mydestination = $myhostname, $mydomain, localhost relay_domains = $mydestination
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.