Mail Server Postfix + Dovecot

2

Estou executando o servidor de e-mail no Ubuntu 12.04 e a caixa tem Servidor da Web + Servidor de E-mail (Postfix + Dovecot). Esta é a configuração da Máquina Virtual na nuvem do Windows Azure.

Problema: não consigo enviar e-mails fora da rede. A seguir estão as configurações e logs.

Postfix:

alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
config_directory = /etc/postfix
dovecot_destination_recipient_limit = 1
inet_interfaces = all
mailbox_size_limit = 0
mydestination = abc.cloudapp.net, localhost.abc.cloudapp.net, localhost
myhostname = abc.cloudapp.net
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
smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)
smtpd_tls_cert_file = /etc/ssl/certs/ssl-cert-snakeoil.pem
smtpd_tls_key_file = /etc/ssl/private/ssl-cert-snakeoil.key
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
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 = dovecot

Dovecot:

# 2.0.19: /etc/dovecot/dovecot.conf
# OS: Linux 3.2.0-65-virtual x86_64 Ubuntu 12.04.4 LTS ext4
auth_mechanisms = plain login
mail_location = maildir:/var/vmail/%d/%n/Maildir
managesieve_notify_capability = mailto
managesieve_sieve_capability = fileinto reject envelope encoded-character vacation subaddress comparator-i;ascii-numeric relational regex imap4flags copy include variables body enotify environment mailbox date ihave
passdb {
  args = /etc/dovecot/dovecot-sql.conf.ext
  driver = sql
}
plugin {
  sieve = ~/.dovecot.sieve
  sieve_dir = ~/sieve
}
protocols = " imap sieve pop3"
service auth {
  unix_listener /var/spool/postfix/private/auth {
    group = postfix
    mode = 0660
    user = postfix
  }
  unix_listener auth-userdb {
    group = vmail
    user = vmail
  }
}
ssl_cert = </etc/ssl/certs/mailserver.pem
ssl_key = </etc/ssl/private/mailserver.pem
userdb {
  args = uid=vmail gid=vmail home=/var/vmail/%d/%n
  driver = static
}
protocol lda {
  mail_plugins = " sieve"
}

/var/log/mail.log

Jul  9 08:40:11 layfootak postfix/smtpd[44127]: connect from unknown[87.109.35.199]
Jul  9 08:40:12 layfootak postfix/smtpd[44127]: NOQUEUE: reject: RCPT from unknown[87.109.35.199]: 554 5.7.1 <[email protected]>: Relay access denied; from=<[email protected]> to=<[email protected]> proto=ESMTP helo=<[127.0.0.1]>

Eu sou capaz de configurar e receber e-mails corretamente com o cliente de e-mail Mozilla Thunderbird. Ele mostra minha caixa de entrada corretamente, mas quando estou enviando um e-mail para outro endereço de e-mail como rede externa, ele concede acesso de retransmissão negado; de = para = proto = ESMTP helo =

Por favor me avise.

Corrigi o problema depois de configurar a seguinte configuração do postfix para configuração de retransmissão de SMTP:

sudo postconf -e smtpd_sasl_type=dovecot
sudo postconf -e smtpd_sasl_path=private/auth
sudo postconf -e smtpd_sasl_auth_enable=yes
sudo postconf -e smtpd_tls_security_level=may
sudo postconf -e smtpd_tls_auth_only=yes
sudo postconf -e smtpd_tls_cert_file=/etc/ssl/certs/mailserver.pem
sudo postconf -e smtpd_tls_key_file=/etc/ssl/private/mailserver.pem
sudo postconf -e smtpd_recipient_restrictions=" \
  permit_mynetworks \
  permit_sasl_authenticated \
  reject_unauth_destination"
    
por user379367 09.07.2014 / 10:44

1 resposta

1

Enviar e-mail para domínios não hospedados no seu Postfix (e-mails externos assim) só é possível para o IP e as redes podem fazer a retransmissão pela configuração do Postfix.

No Postfix, isso é obtido ao fornecer esses IPs e redes permitidos à diretiva de configuração mynetworks em main.cf .

No seu caso, isso mostra que somente o host local tem permissão para retransmitir o e-mail fora da instalação do Postfix.

Para permitir que você envie e-mails para fora sem tornar seu servidor um retransmissor aberto, você deve pelo menos adicionar o IP dos clientes que precisam enviar e-mails externos.

mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128 A.B.C.D/32

Observe o /32 após o endereço IP, isso é para ter certeza de que o Postfix não permitirá a sub-rede inteira, mas apenas aquele endereço específico.

Se todos os clientes estiverem na mesma sub-rede, você pode configurar (exemplo: todos os seus clientes estão conectados a uma rede 192.168.1.0 com 255.255.255.0 como máscara):

mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128 192.168.1.0/24

Claro, se você planeja instalar um software baseado em webmail para seus usuários, o único host permitido para enviar & amp; O relay mail seria o próprio servidor web. Nesse caso, você não precisa modificar a configuração do Postfix, mas certifique-se de que sua solução de webmail use 127.0.0.1 como servidor SMTP.

    
por Benoit 09.07.2014 / 11:00