В дополнение к статье по настройке почтового сервера на FreeBSD решил написать как настроить тоже самое, но на ОС CentOS 6.

Подключаем репозиторий Remi и Epel

rpm --import https://fedoraproject.org/static/0608B895.txt
rpm -Uvh http://download.fedoraproject.org/pub/epel/6/i386/epel-release-6-7.noarch.rpm
yum install yum-priorities
rpm --import http://rpms.famillecollet.com/RPM-GPG-KEY-remi
rpm -ivh http://rpms.famillecollet.com/enterprise/remi-release-6.rpm

Приводим файл /etc/yum.repos.d/epel.repo к такому виду

[epel]
name=Extra Packages for Enterprise Linux 6 - $basearch
#baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch
mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch
failovermethod=priority
enabled=1
priority=10
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6

и файл /etc/yum.repos.d/remi.repo к такому виду:

[remi]
name=Les RPM de remi pour Enterprise Linux $releasever - $basearch
#baseurl=http://rpms.famillecollet.com/enterprise/$releasever/remi/$basearch/
mirrorlist=http://rpms.famillecollet.com/enterprise/$releasever/remi/mirror
enabled=1
priority=10
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-remi
failovermethod=priority

[remi-test]
name=Les RPM de remi en test pour Enterprise Linux $releasever - $basearch
#baseurl=http://rpms.famillecollet.com/enterprise/$releasever/test/$basearch/
mirrorlist=http://rpms.famillecollet.com/enterprise/$releasever/test/mirror
enabled=0
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-remi

Ставим MySQL , добавляем в атозагрузку и стартуем:

yum install mysql mysql-server
chkconfig --levels 235 mysqld on
/etc/init.d/mysqld start

Установим пароь для root в MySQL следующей командой:

mysql_secure_installation

Устанавливаем nginx ( да да, как и в прошлый раз мы обойдемся без тяжеловесного Apache и сделаем все на NGINX + PHP-FPM ), добавим в автозагрузку и стартуем
yum install nginx
chkconfig --levels 235 nginx on
/etc/init.d/nginx start

Ставим PHP-FPM и необходимые модули PHP:

yum --enablerepo=remi,remi-test install php php-fpm php-common php-pear php-pdo php-mysql php-pgsql php-pecl-memcache php-gd php-mbstring php-mcrypt php-xml php-pear-DB php-posix

Приводим файл /etc/php-fpm.conf к такому виду:

[global]
pid = /var/run/php-fpm/php-fpm.pid
error_log = /var/log/php-fpm/error.log
include=/etc/php-fpm.d/*.conf

А файл /etc/php-fpm.d/www.conf к такому:

[www]
listen = /tmp/php-fpm.sock
user = apache
group = apache
pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 35
slowlog = /var/log/php-fpm/www-slow.log
php_admin_value[error_log] = /var/log/php-fpm/www-error.log
php_admin_value[memory_limit] = 128M

Настраиваем nginx. Для этого приводим файл /etc/nginx/nginx.conf к такому виду:

user apache;
worker_processes 2;

error_log /var/log/nginx/error.log;

pid /var/run/nginx.pid;

events {
use epoll;
worker_connections 8192;
}

http {
include /etc/nginx/mime.types;
default_type application/octet-stream;

log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

access_log /var/log/nginx/access.log main;

sendfile on;
client_body_buffer_size 16K;
client_header_buffer_size 1k;
client_max_body_size 32M;
large_client_header_buffers 2 1k;
client_body_timeout 10;
client_header_timeout 10;
keepalive_timeout 5 5;
send_timeout 10;
reset_timedout_connection on;
server_tokens off;
gzip on;

# PHP-FPM

upstream php-fpm {
server unix:/tmp/php-fpm.sock;
}

# Virtual hosts

include /etc/nginx/conf.d/*.conf;

}

и создаем файлы виртуальых хостов:
1) Для Vexim ( /etc/nginx/conf.d/exim.deathstar.name.conf ) файл выглядит вот так:

server
{
listen 80;
server_name exim.deathstar.name;
access_log /var/log/nginx/exim-access.log;
error_log /var/log/nginx/exim-error.log;
root /usr/share/vexim2/vexim;
index index.php;
charset utf-8;

location = /favicon.ico {
log_not_found off;
access_log off;
}

location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}

location ~ .php$
{
fastcgi_pass php-fpm;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}

location ~ /.ht
{
deny all;
}
}

2) Для Roundcube файл ( /etc/nginx/conf.d/mail.deathstar.name.conf ) выглядит так:

server
{
listen 80;
server_name mail.deathstar.name;
access_log /var/log/nginx/mail-access.log;
error_log /var/log/nginx/mail-error.log;
root /usr/share/roundcubemail;
index index.php;
charset utf-8;

location = /favicon.ico {
log_not_found off;
access_log off;
}

location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}

location ~ .php$
{
fastcgi_pass php-fpm;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}

location ~ /.ht
{
deny all;
}
}
и перезагружаем nginx:

/etc/init.d/nginx restart

Устанавливаем Exim,Dovecot и прочее ПО:

yum install -y exim exim-mysql dovecot dovecot-mysql clamd clamav spamassassin

Скачиваем и распаковываем Vexim
cd /usr/share/
wget http://silverwraith.com/vexim/vexim2.2.1.tar.gz
tar zxvf vexim2.2.1.tar.gz
chown -R root:root vexim2/

Копируем конфиги из Vexim в каталог с Exim

mv /etc/exim/exim.conf /etc/exim/exim.conf.bak
cp /usr/share/vexim2/docs/configure /etc/exim/exim.conf
cp /usr/share/vexim2/docs/vexim-* /etc/exim/

Добавляем юзера Vexim

useradd vexim -u 90 -d /usr/local/mail -s /sbin/nologin -m

Устанавливаем БД для Vexim

perl /usr/share/vexim2/setup/create_db.pl --act=newdb --dbtype=mysql --uid=93 –gid=93 --mailstore=/usr/local/mail

Редактируем файл

/usr/share/vexim2/vexim/config/variables.php

и прописываем доступ к БД

$sqldb = "vexim"; имя БД
$sqluser = "vexim"; логин
$sqlpass = "PASSWORD"; пароль заданный ранее

Отключим и удалим Postfix, который по умолчанию уже стоит в системе CentOS 6.

alternatives --config mta
chkconfig --level 123456 postfix off
service postfix stop
yum remove postfix -y

Отключаем SELINUX:
echo 'SELNIUX=disabled' >> /etc/selinux/config

Добавлеяем сервисов в автозагрузку
chkconfig --level 35 clamav on
chkconfig --level 35 spamassasin on
chkconfig --level 35 exim on
chkconfig --level 35 dovecot on

Выставляем права:

usermod -a -G exim clamav
chmod -Rf g+w /var/spool/exim
chmod -Rf g+s /var/spool/exim
chown exim:exim -R /usr/local/mail
chown exim:exim -R /var/spool/exim

Правим пути в конфиге Exim:

cd /etc/exim/
sed -i.bak -e ‘s//usr/local/etc//etc/g’ exim.conf
sed -i.bak -e ‘s/MAILMAN_USER=mailnull/MAILMAN_USER=exim/g’ -e ‘s/MAILMAN_GROUP=mail/MAILMAN_GROUP=exim/g’ exim.conf

Находим в конфигe exim строку:
MY_IP = CHANGE и описываем свой ip
MY_IP = 46.38.63.5
Находим:
trusted_users = avleen:www
и меняем на apache . Остается:

trusted_users = apache
Менякем юзера, от которого будет запускаться exim, меняем строки

exim_user = mailnull
exim_group = mail

на
exim_user = exim
exim_group = exim

Находим закоментированную строку, отвечающую за подключение к MySQL серверу,раскоментируем ее и поставим там свой пароль:
hide mysql_servers = localhost::(/tmp/mysql.sock)/vexim/vexim/PASSWORD

Находим секцию system_aliases: и в ней меняем строки

user = mailnull
group = mail

на
user = exim
group = exim

И запускаем:
service exim start

Настраиваем Dovecot:
Приводим конфиг /etc/dovecot/dovecot.conf к такому виду:

base_dir = /var/run/dovecot/
disable_plaintext_auth = no
first_valid_uid = 93
listen = *
login_greeting = Dovecot ready man.
login_log_format_elements = user=< %u> method=%m rip=%r lip=%l %c
mail_location = maildir:~/Maildir
log_path =/var/log/dovecot

# Log file to use for informational and debug messages.
# Default is the same as log_path.
#info_log_path =

# Prefix for each line written to log file. % codes are in strftime(3)
# format.
log_timestamp = "%b %d %H:%M:%S "

passdb {
driver = pam
}
passdb {
args = /etc/dovecot/dovecot-mysql.conf
driver = sql
}
protocols = imap pop3
service auth {
unix_listener auth-master {
group = exim
mode = 0660
user = exim
}
user = root
}
service imap-login {
chroot =
client_limit = 256
process_limit = 128
process_min_avail = 3
service_count = 1
vsz_limit = 64 M
}
service pop3-login {
chroot =
client_limit = 256
process_limit = 128
process_min_avail = 3
service_count = 1
vsz_limit = 64 M
}
ssl = no
userdb {
driver = passwd
}
userdb {
args = /etc/dovecot/dovecot-mysql.conf
driver = sql
}
protocol imap {
imap_client_workarounds = tb-extra-mailbox-sep
mail_plugins = quota imap_quota
}
protocol pop3 {
pop3_client_workarounds = outlook-no-nuls oe-ns-eoh
pop3_uidl_format = %08Xu%08Xv
}

Настраиваем подключение к MySQL в файле /etc/dovecot/dovecot-mysql.conf
driver = mysql
connect = host=/var/lib/mysql/mysql.sock user=vexim password=PASSWORD dbname=vexim
default_pass_scheme = MD5-CRYPT
password_query = SELECT crypt as `password` FROM users,domains WHERE users.username = '%u' AND users.enabled = '1' AND users.type = 'local' and domains.enabled = '1' and domains.domain_id = users.domain_id
user_query = SELECT pop as home, uid, gid FROM users WHERE username = '%u'

И запускаем все:

/etc/init.d/dovecot start
/etc/init.d/clamav start
/etc/init.d/spamassassin start

Устанавливаем roundcube

cd /usr/share
wget http://sourceforge.net/projects/roundcubemail/files/roundcubemail/0.8.1/roundcubemail-0.8.1.tar.gz
tar zxvf roundcubemail-0.8.1.tar.gz

mv roundcubemail-0.8.1 roundcubemail
chown -R apache:apache roundcubemail/
chmod -R 777 roundcubemail/temp/ roundcubemail/logs/

Создаем базу

mysql -p
Enter password: ( вводим пароль от root MySQL )
Welcome to the MySQL monitor. Commands end with ; or g.

Вводим команду
CREATE DATABASE roundcubemail DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

И команду
GRANT ALL PRIVILEGES ON roundcubemail.* TO roundcube@localhost IDENTIFIED BY 'password'; ( вместо password пишем пароль для юзера roundcube )

и выходим командой quit

Импортируем БД
mysql -p roundcubemail < roundcubemail/SQL/mysql.initial.sql ( вводим пароль от root MySQL )

Копируем конфиги

cp roundcubemail/config/db.inc.php.dist roundcubemail/config/db.inc.php
cp roundcubemail/config/main.inc.php.dist roundcubemail/config/main.inc.php

редактируем файл roundcubemail/config/db.inc.php

и вместо pass пишем пароль заведенный для юзера roundcube
$rcmail_config['db_dsnw'] = 'mysql://roundcube:pass@localhost/roundcubemail';

Редактируем roundcubemail/config/main.inc.php

и заменяем в нем строки:
$rcmail_config['default_host'] = ''; на
$rcmail_config['default_host'] = 'localhost';

$rcmail_config['smtp_server'] = ''; на
$rcmail_config['smtp_server'] = 'localhost';

$rcmail_config['smtp_user'] = ''; на

$rcmail_config['smtp_user'] = '%u';

$rcmail_config['smtp_pass'] = ''; на
$rcmail_config['smtp_pass'] = '%p';

$rcmail_config['smtp_auth_type'] = ''; на
$rcmail_config['smtp_auth_type'] = 'CRAM-MD5';

$rcmail_config['language'] = ; на
$rcmail_config['language'] = ru_RU;

$rcmail_config['create_default_folders'] = false; на
$rcmail_config['create_default_folders'] = true;

$rcmail_config['default_charset'] = ''; на
$rcmail_config['default_charset'] = 'UTF-8';

и сохраняем.

Теперь Roundcube доступен по адресу http://mail.deathstar.name а Vexim по http://exim.deathstar.name