Mail-Server с защитой от спама и вирусов

1.1. Требования к системе

В качестве платформы используется Debian GNU/Linux 4.0 etch http://www.debian.org/News/2007/20070817. Для создания данного сервера применялась связка из: Postfix, Amavis, Clamav, Spamassassin. Для доставки писем применяется courier-imap и courier-pop. Данный сервер не требователен к ресурсам. В качестве аппаратной части, достаточен любой стандартный компьютер на процессоре P2 и выше. В качестве дискового хранилища вполне подойдет софтовой рейд.

1.1.1. Установка компонентов

В Debian установка пакетов не представляет большой сложности:

sudo apt-get install postfix courier-imap courier-pop amavisd-new clamav clamav-daemon spamassassin

1.2. Компоненты

Ниже приведены примеры настройки составных частей сервера.

1.2.1. Postfix

Postfix это популярный  MTA. По своему быстродействию и надежности практически не уступает Sendmail. Учитывая что Postfix позволяет подключать к себе дополнительные фильтры сообщений, мы будем использовать его в связке с почтовым фильтром Amavis.

1.2.1.1 Настройка Postfix

Для создания данного сервера потребуется внести коррективы в следующие файлы: /etc/mailname  /etc/postfix/main.cf  /etc/postfix/master.cf  /etc/amavis/conf.d/20-debian_defaults  /etc/courier/imapd  /etc/courier/pop3d

1.2.1.2 mailname

Впишите в /etc/mailname название вашего сервера. Оно должно быть таким-же, как в записи MX1 вашего DNS. Ссылка на /etc/mailname находиться в /etc/postfix/main.cf.

1.2.1.3 main.cf

Ниже приведены основные компоненты конфигурационного файла: /etc/postfix/main.cf.

myhostname: Название вашего компьютера + его доменная часть.

myhostname = oes.msk.local.net

mydestination: Сюда надо вписать домены, для которых сервер будет принимать почту.

mydestination = msk.org.net, msk.local.net, oes.msk.local.net, localhost.msk.local.net, localhost

mynetworks: Сюда необходимо вписать подсети, которым разрешено отправлять почту через этот сервер. Как минимум, это ”обратная петля” (127.0.0.0/8) и ваша локальная сеть, на пример (192.168.0.1/24).

mynetworks = 127.0.0.0/8, 192.168.0.0/24

mailbox_command: До настройки Courier-imap и Courier-pop данную директиву надо оставить раскомментированной, так проще настраивать и тестировать ”голый” Postfix, но после настройки и запуска этих служб доставки писем ее надо отключить! Так, как по умолчанию, она будет конфликтовать со службами доставки почты.

mailbox_command = procmail -a "$EXTENSION"

mailbox_size_limit: Ограничивает размер сообщений. Необходима для предотвращения MailBomb-атак на майл-сервер. По умолчанию отключена. Потому желательно за место нуля указать в байтах максимальную величину письма, например 10 Мб. а лучше еще меньше.

#mailbox_size_limit = 0
message_size_limit = 10242880

smtpd_recipient_limit: Ограничивает число CC в одном письме.

smtpd_recipient_limit = 10

home_mailbox: Директива home_mailbox2 определяет название каталога для хранения почты, которая в свою очередь будет размещаться в домашнем каталоге пользователя. Внимание! не забудьте указать это тот-же каталог при настройке courier-imap и courier-pop. В противном случае, почта будет доставляться в каталог по умолчанию — Mail. В случае, если каталоги пользователей будут расшарены в локальной сети — данные изменения необходимы для того, чтобы пользователь по неосторожности не удалил свой почтовый каталог. Так как название каталогов, с расположенной в начале имени каталога точкой — отображаются как скрытые каталоги. Вероятность их случайного удаления значительно снижается.

home_mailbox = .maildir/

Для уменьшения поступаемого на почтовый сервер спама, рекомендуется внести следующие директивы: smtpd_helo_required и strict_rfc821_envelopes. Это предотвратит приём почты от некачественных ”самодельных” почтовых клиентов, и большого кол-ва спам-роботов. Это связанно с тем, что в большинстве случаем, при написании подобных клиентов и роботов-рассылки их создатели не утруждают себя следовать необходимым стандартам: ”на пример rfs821”.

smtpd_helo_required = yes
strict_rfc821_envelopes = yes

Не принимать почту от серверов, которые не знают имени своего хоста.

smtpd_helo_restrictions = permit_mynetworks,   reject_unknown_hostname, reject_invalid_hostname, reject_non_fqdn_hostname, reject_unknown_sender_domain, reject_unknown_recipient_domain

Не принимать почту от доменов, которые не существуют.

smtpd_sender_restrictions = reject_unknown_sender_domain
#mailbox_command = procmail -a "$EXTENSION"

На этом базовая настройка Postfix закончена, далее приведен пример кода для подключения Postfix к Amavis.

content_filter = amavis:[127.0.0.1]:10024   receive_override_options = no_address_mappings

Вот пример рабочего конфигурационного файла.

myorigin = /etc/mailname  

smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU)
biff = no  

append_dot_mydomain = no  

# Uncomment the next line to generate "delayed mail" warnings
#delay_warning_time = 4h  

# TLS parameters
smtpd_tls_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
smtpd_tls_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
smtpd_use_tls=yes
smtpd_tls_session_cache_database = btree:${queue_directory}/smtpd_scache
smtp_tls_session_cache_database = btree:${queue_directory}/smtp_scache  

# See /usr/share/doc/postfix/TLS_README.gz in the postfix-doc package for
# information on enabling SSL in the smtp client.  

myhostname = oes.msk.local.net
alias_maps = hash:/etc/aliases
alias_database = hash:/etc/aliases
myorigin = /etc/mailname  

mydestination = msk.org.net, msk.local.net, localhost
#mydestination = msk.org.net, msk.local.net, oes.msk.local.net, localhost.msk.local.net, localhost  

#mydestination = $myhostname, localhost, localhost.$mydomain, msk.org.net, msk.local.net,
#moscow.org.net, asus.msk.local.net  

relayhost =
mynetworks = 127.0.0.0/8, 192.168.0.0/24  

#mailbox_command = procmail -a "$EXTENSION"  

mailbox_size_limit = 0
recipient_delimiter = +
##Ограничичиваем saze
#message_size_limit = 20485760
message_size_limit = 10242880
#Ограничичиваем число CC в одном письме.
smtpd_recipient_limit = 10  

#Только правельные почтовые клиенты!!!
smtpd_helo_required = yes
strict_rfc821_envelopes = yes  

# Не общаться с почтовыми системами, которые не знают  имени своего хоста.
smtpd_helo_restrictions =  permit_mynetworks, reject_unknown_hostname, reject_invalid_hostname, reject_non_fqdn_hostname, reject_unknown_sender_domain, reject_unknown_recipient_domain
# Не принимать почту от доменов, которые не существуют.
smtpd_sender_restrictions = reject_unknown_sender_domain  

home_mailbox = .maildir/  

inet_interfaces = all
# content_filter = amavis:[127.0.0.1]:10024
# receive_override_options = no_address_mappings

1.2.1.4 master.cf Изначально Postfix лучше настраивать без подключения к Amavis. В этом случае master.cf трогать не следует. Но после настройки и проверки работы Postfix, для создания связки Postfix + Amavis необходимо в master.cf внести ниже перечисленные строки.

amavis unix - - - - 2 smtp
-o smtp_data_done_timeout=1200
-o smtp_send_xforward_command=yes  

127.0.0.1:10025 inet n - - - - smtpd
-o content_filter=
-o local_recipient_maps=
-o relay_recipient_maps=
-o smtpd_restriction_classes=
-o smtpd_client_restrictions=
-o smtpd_helo_restrictions=
-o smtpd_sender_restrictions=
-o smtpd_recipient_restrictions=permit_mynetworks,reject
-o mynetworks=127.0.0.0/8
-o strict_rfc821_envelopes=yes
-o receive_override_options=no_unknown_recipient_checks, no_header_body_checks
-o smtpd_bind_address=127.0.0.1

Ниже приведен пример master.cf.

#
# Postfix master process configuration file.  For details on the format
# of the file, see the master(5) manual page (command: "man 5 master").
#
# ==========================================================================
# service type  private unpriv  chroot  wakeup  maxproc command + args
#               (yes)   (yes)   (yes)   (never) (100)
# ==========================================================================
smtp      inet  n       -       -       -       -       smtpd
#submission inet n       -       -       -       -       smtpd
#  -o smtpd_enforce_tls=yes
#  -o smtpd_sasl_auth_enable=yes
#  -o smtpd_client_restrictions=permit_sasl_authenticated,reject
#smtps     inet  n       -       -       -       -       smtpd
#  -o smtpd_tls_wrappermode=yes
#  -o smtpd_sasl_auth_enable=yes
#  -o smtpd_client_restrictions=permit_sasl_authenticated,reject
#628      inet  n       -       -       -       -       qmqpd
pickup    fifo  n       -       -       60      1       pickup
cleanup   unix  n       -       -       -       0       cleanup
qmgr      fifo  n       -       n       300     1       qmgr
#qmgr     fifo  n       -       -       300     1       oqmgr
tlsmgr    unix  -       -       -       1000?   1       tlsmgr
rewrite   unix  -       -       -       -       -       trivial-rewrite
bounce    unix  -       -       -       -       0       bounce
defer     unix  -       -       -       -       0       bounce
trace     unix  -       -       -       -       0       bounce
verify    unix  -       -       -       -       1       verify
flush     unix  n       -       -       1000?   0       flush
proxymap  unix  -       -       n       -       -       proxymap
smtp      unix  -       -       -       -       -       smtp
# When relaying mail as backup MX, disable fallback_relay to avoid MX loops
relay     unix  -       -       -       -       -       smtp
-o fallback_relay=
#       -o smtp_helo_timeout=5 -o smtp_connect_timeout=5
showq     unix  n       -       -       -       -       showq
error     unix  -       -       -       -       -       error
discard   unix  -       -       -       -       -       discard
local     unix  -       n       n       -       -       local
virtual   unix  -       n       n       -       -       virtual
lmtp      unix  -       -       -       -       -       lmtp
anvil     unix  -       -       -       -       1       anvil
scache    unix  -       -       -       -       1       scache
#
# ====================================================================
# Interfaces to non-Postfix software. Be sure to examine the manual
# pages of the non-Postfix software to find out what options it wants.
#
# Many of the following services use the Postfix pipe(8) delivery
# agent.  See the pipe(8) man page for information about ${recipient}
# and other message envelope options.
# ====================================================================
#
# maildrop. See the Postfix MAILDROP_README file for details.
# Also specify in main.cf: maildrop_destination_recipient_limit=1
#
maildrop  unix  -       n       n       -       -       pipe
flags=DRhu user=vmail argv=/usr/bin/maildrop -d ${recipient}
#
# See the Postfix UUCP_README file for configuration details.
#
uucp      unix  -       n       n       -       -       pipe
flags=Fqhu user=uucp argv=uux -r -n -z -a$sender - $nexthop!rmail ($recipient)
#
# Other external delivery methods.
#
ifmail    unix  -       n       n       -       -       pipe
flags=F user=ftn argv=/usr/lib/ifmail/ifmail -r $nexthop ($recipient)
bsmtp     unix  -       n       n       -       -       pipe
flags=Fq. user=bsmtp argv=/usr/lib/bsmtp/bsmtp -t$nexthop -f$sender $recipient
scalemail-backend unix  -       n       n       -       2       pipe
flags=R user=scalemail argv=/usr/lib/scalemail/bin/scalemail-store ${nexthop} ${user} ${extension}
mailman   unix  -       n       n       -       -       pipe
flags=FR user=list argv=/usr/lib/mailman/bin/postfix-to-mailman.py
${nexthop} ${user}  

amavis unix - - - - 2 smtp
-o smtp_data_done_timeout=1200
-o smtp_send_xforward_command=yes  

127.0.0.1:10025 inet n - - - - smtpd
-o content_filter=
-o local_recipient_maps=
-o relay_recipient_maps=
-o smtpd_restriction_classes=
-o smtpd_client_restrictions=
-o smtpd_helo_restrictions=
-o smtpd_sender_restrictions=
-o smtpd_recipient_restrictions=permit_mynetworks,reject
-o mynetworks=127.0.0.0/8
-o strict_rfc821_envelopes=yes
-o receive_override_options=no_unknown_recipient_checks,no_header_body_checks
-o smtpd_bind_address=127.0.0.1

1.2.2. Amavis Amavis напоминает конвейер по проверке проходящей через MTA сообщений. Рис. 1.1: Схема взаимодействия Postfix c Amavis 1.2.2.1 Настройка Amavis В Debian 4.0 Amavis практически не требует настроек. Кроме одного немаловажного момента. По умолчанию, нежелательная почта помеченная как Spam — не попадает в почтовые ящики пользователей. То есть, полностью отвергается. Как показывает практика, это не самая хорошая идея. Так как среди определенных как spam писем, могут быть нужные письма. Для этого отредактируйте /etc/amavis/conf.d/20-debian_defaults: Найдите строчку:

$final_spam_destiny = D_BOUNCE;

и переправьте ее на:

$final_spam_destiny = D_PASS;

Теперь необходимо подключить Amavis к Postfix. Для этого раскомментируйте нижние 2 строчки в /etc/postfix/main.cf .

content_filter = amavis:[127.0.0.1]:10024
receive_override_options = no_address_mappings

После перезапуска Postfix, проверяем наличие сокета Amavis и Postfix No Content Filter .

# telnet localhost 10025
Trying 127.0.0.1...
Connected to localhost.
Escape character is ’̂]’.
220 oes.msk.local.net ESMTP Postfix (Debian/GNU)  

# telnet localhost 10024
Trying 127.0.0.1...
Connected to localhost.
Escape character is ’̂]’.
220 [127.0.0.1] ESMTP amavisd-new service ready

Для того, чтобы Amavis обрабатывал spam и вирусы, в файле /etc/amavis/conf.d/15-content_filter_mode Раскомментируйте строчки:

@bypass_virus_checks_maps = (%bypass_virus_checks, \@bypass_virus_checks_acl, $bypass_virus_checks_re);  

@bypass_spam_checks_maps = (%bypass_spam_checks, \@bypass_spam_checks_acl, $bypass_spam_checks_re);

1.2.3. Courier-Imap Данная служба обеспечивает взаимодействие пользователя с его каталогами размещенных на постовом сервере. 1.2.3.1 Настройка Courier-Imap Практически не требует никакой настройки за исключением места расположения почтового каталога. По умолчанию, директива MAILDIRPATH имеет значение Mail что не очень хорошо, так как для пользователя данный каталог является видимым. И потому, может быть случайно удален. Потому, целесообразнее его сделать скрытым. nano /etc/courier/imapd

#MAILDIRPATH=Maildir
MAILDIR=.maildir
MAILDIRPATH=.maildir

1.2.4. Courier-POP Так-же как и Courier-Imap, практически не требует настроек. 1.2.4.1 Настройка Courier-POP nano /etc/courier/pop Настройка аналогична Courier-Imap. 1 MX или Mail Exchanger, доменная часть адреса e-mail. Читайте про настройку DNS — серверов, например BIND. Если вы собираетесь использовать данную директиву, не забудьте закомментировать директиву mailbox_command, или переправить ее значение на sendmail. Если вам, для доставки почты необходимо использовать procmail, то его придется настраивать отдельно на доставку почты в каталог пользователя! 3 Если вы не собираетесь расшаривать домашние каталоги, то эта предосторожность не нужна.

Запись опубликована в рубрике Debian, Сервер с метками . Добавьте в закладки постоянную ссылку.

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

Анти-спам: выполните заданиеWordPress CAPTCHA