RedHat el5.0 搭建 Postfix 邮件服务器系统
(postfix+cyrus-sasl2+courier-authlib+courier-imap+extmail+maildrop)
一、系统环境
操作系统:rhel-5.2
所需软件(按网上以前的文档,好多版本都找不到,只能找相近的,下面都是在实验后都可以使用的包2010/10/27)
httpd-2.2.0.tar.bz2 架设web用于extman的后台管理,extmail 的web邮件收发
php-5.2.14.tar.gz Php 解释器,extman & extmail 需要使用php
mysql-5.1.37.tar.gz 用于存储虚拟域、虚拟账户信息
postfix-2.4.5.tar.gz 邮件服务器系统的smtp服务器,充当MTA
cyrus-sasl-2.1.22.tar.gz 用于实现身份验证的 smtp 服务器
courier-authlib-0.58.tar.bz2 实现带验证的 pop3 服务器
courier-imap-4.2.0.tar.bz2 用于实现 pop3、imap 收邮件功能
extmail-1.1.0.tar.gz 用于实现 webmail
extman-0.2.5.tar.gz 用于邮件服务器的后台管理
openssl-0.9.8e.tar.gz 提供安全的邮件服务器连接
DBD-mysql-2.9008.tar.gz 用于解决依赖关系,extmail 将会用到
Unix-Syslog-1.1.tar.gz 用于解决依赖关系,extmail 将会用到
BerkeleyDB(db-4.5.20.tar.gz) 在编译postfix要使用
maildrop-2.0.4.tar.bz2 用来代替postfix自带的MDA,是一个带有过滤功能的MDA
pcre-7.2.tar.bz2 用于安装maildrop
系统禁用 selinux
二、软件安装
1、安装apache
tar zxvf httpd-2.2.0.tar.gz
cd httpd-2.2.0
./configure --prefix=/usr/local/apache --enable-so
make
make install
安装最主要的是mod_so模块httpd –l检测mod_so.c,目的是为了以模块方式加载php
2、安装 mysql
tar xvf mysql-5.1.37.tar.gz
cd mysql-5.1.37
./configure -prefix=/usr/local/mysql
make&&make install
useradd mysql
cp support-files/my-medium.cnf /etc/my.cnf
cd /usr/local/mysql
/usr/local/mysql/bin/mysql_install_db --user=mysql //初始化数据库
chown -R root .
chown -R mysql var
chgrp -R mysql .
echo "/usr/local/mysql/lib/mysql">>/etc/ld.so.conf
ldconfig
echo "export PATH=$PATH:/usr/local/mysql/bin">>/etc/profile
source /etc/profile
上面这几行红色的字,必须要添加,否则在安装过程中会出现很多错误,还在注意在/tmp目录下是否存在 mysql.sock 这个文件,如果没有的话,就要做一个链接了,避免mysql在启动时报错
复制一个编译目录的脚本,以使 mysql 每次启动时都能自动运行,回到编译的目录mysql-5.1.37
cp support-files/mysql.server /etc/rc.d/init.d/mysqld
chkconfig --add mysqld
chkconfig --level 35 mysqld on
service mysqld start
3、安装php
tar –xvf php-5.2.14.tar.gz
cd php-5.2.14
./configure -prefix=/usr/local/php -with-apxs2=/usr/local/apache/bin/apxs -with-mysql=/usr/local/mysql
make&&make install
cp php.ini-dist /usr/local/php/lib/php.ini
修改apache的配置文件 httpd.conf加上"AddType application/x-httpd-php .php,定位至 DirectoryIndex index.html ,修改为: DirectoryIndex index.php index.html
在目录/usr/local/apache/htdocs下创建一个最简单的php测试文件,其内容为:
vi test.php
<?
phpinfo();
?>
检查一下apache配置文件是否正确(/usr/local/apache/bin/apachectl -t),输出"Syntax OK"后就可以启动apache服务(/usr/local/apache/bin/apachectl start)。
在浏览器上测试test.php,会看到php的信息
4、安装 openssl
tar zxvf openssl-0.9.8e.tar.gz
./config shared zlib
make
make test
make install
mv /usr/bin/openssl /usr/bin/openssl.OFF
mv /usr/include/openssl /usr/include/openssl.OFF
rm -rf /usr/lib/libssl.so
ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl
ln -s /usr/local/ssl/include/openssl /usr/include/openssl
ln -sv /usr/local/ssl/lib/libssl.so.0.9.8 /usr/lib/libssl.so
echo "/usr/local/ssl/lib" >> /etc/ld.so.conf
ldconfig
检查是否安装 openssl
openssl version
OpenSSL 0.9.8e 23 Feb 2007
5、安装 courier-authlib
tar jxvf courier-authlib-0.58.tar.bz2
cd courier-authlib-0.58
. /configure --prefix=/usr/local/authlib --without-authpam --without-authldap --without-authpwd --without-authpgsql --with-authmysql --without-authshadow --without-authvchkpw --with-mysql-libs=/usr/local/mysql/lib/mysql --with-mysql-includes=/usr/local/mysql/include/mysql --with-redhat CFLAGS="-march=i686 -O2 -fexpensive-optimizations" CXXFLAGS="-march=i686 -O2 -fexpensive-optimizations"
make && make install
chmod 755 /usr/local/authlib/var/spool/authdaemon
cp /usr/local/authlib/etc/authlib/authdaemonrc.dist /usr/local/authlib/etc/authlib/authdaemonrc
cp /usr/local/authlib/etc/authlib/authmysqlrc.dist /usr/local/authlib/etc/authlib/authmysqlrc
vi /usr/local/courier-authlib/etc/authlib/authdaemonrc
authmodulelist="authmysql"
authmodulelistorig="authmysql"
daemons=10
vi /usr/localcourier-authlib/etc/authlib/authmysqlrc
MYSQL_SERVER localhost
MYSQL_PORT 3306
MYSQL_USERNAME extmail
MYSQL_PASSWORD extmail
MYSQL_SOCKET /tmp/mysql.sock
MYSQL_DATABASE extmail
MYSQL_USER_TABLE mailbox
MYSQL_CRYPT_PWFIELD password
MYSQL_UID_FIELD '2525'
MYSQL_GID_FIELD '2525'
MYSQL_LOGIN_FIELD username
MYSQL_HOME_FIELD concat('/var/mailbox/',homedir)
MYSQL_NAME_FIELD name
MYSQL_MAILDIR_FIELD concat('/var/mailbox/',maildir)
注:其中 2525,2525为postfix用户的UID和GID(这里可先设置id号,当建postfix用户时,可指定uid,gid要注意对应即可,这个文件中不能出现空格,或者会出现错误
设置 courier-authlib 自启动
cp courier-authlib.sysvinit /etc/init.d/courier-authlib
chmod 755 /etc/init.d/courier-authlib
chkconfig --add courier-authlib
chkconfig --level 2345 courier-authlib on
echo "/usr/local/authlib/lib/courier-authlib" >> /etc/ld.so.conf
ldconfig
service courier-authlib start
6、安装 courier-sasl
删除以前的rpm包以及相关目录,系统自带的与authlib配合不好
rpm –qa | grep sasl 显示出已安装的都要删除
rpm -e --nodeps cyrus-sasl-2.1.10-4 cyrus-sasl-plain-2.1.10-4 cyrus-sasl-md5-2.1.10-4 cyrus-sasl-devel-2.1.10-4 …
rm -rf /usr/lib/sasl
rm -rf /usr/lib/sasl2
tar –xvf cyrus-sasl-2.1.22.tar.gz (使用2.1.21版本,在make时报错,网上查要sasl.patch补丁,也没启作用,最后还是选择了2.1.22版本)
cd cyrus-sasl-2.1.22
./configure --enable-plain --enable-cram --enable-digest --enable-login --enable-sql --disable-anon --disable-ntlm --disable-gssapi --disable-krb4 --disable-otp --disable-srp --disable-srp-setpass --with-authdaemond=/usr/local/authlib/var/spool/authdaemon/socket
--with-mysql=/usr/local/mysql --with-mysql-includes=/usr/local/mysql/include/mysql --with-mysql-libs=/usr/local/mysql/lib/mysql
make
make install
ln -s /usr/local/lib/sasl2 /usr/lib/sasl2
增加"/usr/local/lib"到你的"/etc/ld.so.conf",并执行ldconfig命令。
vi /usr/local/lib/sasl2/smtpd.conf
pwcheck_method: authdaemond
log_level: 3
mech_list: PLAIN LOGIN
authdaemond_path:/usr/local/authlib/var/spool/authdaemon/socket
注意,这个文件的编辑不要多写一个空格,否则会出现smtp验证不过的问题
7、安装 Berkeley-DB
tar zxvf db-4.5.20.tar.gz
cd db-4.5.20/build_unix
../dist/configure —prefix=/usr/local/BerkeleyDB
make
make install
mv /usr/inculde/db4 /usr/inculde/db4.OFF
rm -rf /usr/inculde/db_cxx.h
rm -rf /usr/inculde/db.h
rm -rf /usr/inculde/db_185.h
ln -s /usr/local/BerkeleyDB/include /usr/include/db4
ln -s /usr/local/BerkeleyDB/include/db.h /usr/include/db.h
ln -s /usr/local/BerkeleyDB/include/db_cxx.h /usr/include/db_cxx.h
echo "/usr/local/BerkeleyDB/lib" >> /etc/ld.so.conf
ldconfig
8、安装 postfix
groupadd -g 2525 postfix
useradd -g postfix -u 2525 -s /sbin/nologin -M postfix
groupadd -g 2526 postdrop
useradd -g postdrop -u 2526 -s /bin/false -M postdrop
service sendmail stop
mv /usr/sbin/sendmail /usr/sbin/sendmail.OFF
mv /usr/bin/mailq /usr/bin/mailq.OFF
mv /usr/bin/newaliases /usr/bin/newaliases.OFF
tar zxvf postfix-2.4.5.tar.gz
cd postfix-2.4.5
make makefiles 'CCARGS=-DHAS_MYSQL -I/usr/local/mysql/include/mysql -DUSE_SASL_AUTH -DUSE_CYRUS_SASL -I/usr/local/sasl2/include/sasl -I/usr/local/BerkeleyDB/include -DUSE_TLS -I/usr/local/ssl/include/openssl ' 'AUXLIBS=-L/usr/local/mysql/lib/mysql -lmysqlclient -lz -lm -L/usr/local/sasl2/lib -lsasl2 -L/usr/local/BerkeleyDB/lib -L/usr/local/ssl/lib -lssl -lcrypto'
make
make install
tempdir: [/root/ postfix-2.4.5]
config_directory: [/etc/postfix]
daemon_directory: [/usr/libexec/postfix]
command_directory: [/usr/sbin]
queue_directory: [/var/spool/postfix]
sendmail_path: [/usr/sbin/sendmail]
newaliases_path: [/usr/bin/newaliases]
mailq_path: [/usr/bin/mailq]
mail_owner: [postfix]
setgid_group: [postdrop]
html_directory: [no]
manpages: [/usr/local/man]
readme_directory: [no]
上面的选项全部保持默认,直接回车即可。
事先要执行:echo “/usr/local/ssl/lib” >> /etc/ld.so.conf
ldconig 避免出现错误
生成别名二进制文件,这个步骤如果忽略,会造成 postfix 效率极低:
newaliases
配置 postfix
vi /etc/postfix/main.cf
myhostname = mail.wlq.com
mydomain = wlq.com
myorigin = $mydomain
inet_interfaces = all
mynetworks = 192.168.1.0/24, 127.0.0.0/8
#================Virtual Setting ====================
virtual_mailbox_base = /var/mailbox/
virtual_mailbox_maps= mysql:/etc/postfix/mysql/mysql_virtual_mailbox_maps.cf
virtual_mailbox_domains=mysql:/etc/postfix/mysql/mysql_virtual_domains_maps.cf
virtual_alias_domains =
virtual_alias_maps = mysql:/etc/postfix/mysql/mysql_virtual_alias_maps.cf
virtual_uid_maps = static:2525
virtual_gid_maps = static:2525
virtual_transport = virtual
maildrop_destination_recipient_limit = 1
maildrop_destination_concurrency_limit = 1
#=================Quota Setting ====================
message_size_limit = 14336000
virtual_mailbox_limit = 20971520
virtual_create_maildirsize = yes
virtual_mailbox_extended = yes
virtual_mailbox_limit_maps
mysql:/etc/postfix/mysql/mysql_virtual_mailbox_limit_maps.cf
virtual_mailbox_limit_override = yes
virtual_maildir_limit_message = Sorry,the user's maildir has overdrawn his diskspace quota,please Tidy your mailbox and try again later.
virtual_overquota_bounce = yes
#=================== Cyrus-sasl=====================
broken_sasl_auth_clients = yes
smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_invalid_hostname,reject_non_fqdn_hostname,
reject_unknown_sender_domain,reject_non_fqdn_sender,
reject_non_fqdn_recipient,reject_unknown_recipient_domain, reject_unauth_pipelining,
reject_unauth_destination, permit
smtpd_sasl_auth_enable = yes
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_security_options = noanonymous
smtpd_sasl_application_name = smtpd
smtpd_banner = Welcome to our $myhostname ESMTP, Warning:Version not Available!
local_recipient_maps = (也要填加这一条,我也是最后在web界面发邮件时老报local_recipient的错,填加这一条后就好了)
# mkdir -p /etc/postfix/mysql
cd /etc/postfix/mysql
vi mysql_virtual_alias_maps.cf
user = extmail
password = extmail
hosts = localhost
dbname = extmail
table = alias
select_field = goto
where_field = address
vi mysql_virtual_mailbox_limit_maps.cf
user = extmail
hosts = localhost
dbname = extmail
table = mailbox
select_field = quota
where_field = username
vi mysql_virtual_domains_maps.cf
user = extmail
password = extmail
hosts = localhost
dbname = extmail
table = domain
select_field = description
where_field = domain
vi mysql_virtual_mailbox_maps.cf
user = extmail
password = extmail
hosts = localhost
dbname = extmail
table = mailbox
select_field = maildir
where_field = username
9、安装 Courier-IMAP
tar –xvjf courier-imap-4.2.0.tar.bz2
cd courier-imap-4.2.0
./configure --prefix=/usr/local/imap --with-redhat --enable-unicode --disable-root-check --with-trashquota CPPFLAGS='-I/usr/local/ssl/include/openssl -I/usr/local/authlib/include' LDFLAGS='-L/usr/local/authlib/lib/courier-authlib' COURIERAUTHCONFIG='/usr/local/authlib/bin/courierauthconfig'
make
make install
cp /usr/local/imap/etc/imapd.dist /usr/local/imap/etc/imapd
cp /usr/local/imap/etc/imapd-ssl.dist /usr/local/imap/etc/imapd-ssl
cp /usr/local/imap/etc/pop3d.dist /usr/local/imap/etc/pop3d
cp /usr/local/imap/etc/pop3d-ssl.dist /usr/local/imap/etc/pop3d-ssl
vi /usr/local/imap/etc/pop3d
POP3DSTART=YES
注:如果你想为用户提供 IMAP 服务,则需在"/usr/local/courier-imap/etc/imapd"文件中设置"IMAPDSTART=yes";其它类同;
新建虚拟用户邮箱所在的目录,并将其权限赋予 postfix 用户:
mkdir -p /var/mailbox
chown -R postfix /var/mailbox
cp courier-imap.sysvinit /etc/rc.d/init.d/imapd
chmod 755 /etc/rc.d/init.d/imapd
chkconfig --add imapd
chkconfig --level 2345 imapd on
service imapd start
10、安装 extmail
tar –xvf extmail-1.1.0.tar.gz
mkdir -pv /var/www/extsuite
mv extmail-1.1.0 /var/www/extsuite/extmail
cp /var/www/extsuite/extmail/webmail.cf.default /var/www/extsuite/extmail/webmail.cf
vi /var/www/extsuite/extmail/webmail.cf (下列选项为修改后的)
SYS_MESSAGE_SIZE_LIMIT = 5242880 用户可以发送的最大邮件
SYS_USER_LANG = zh_CN
SYS_MAILDIR_BASE = /var/mailbox/ 用户邮件的存放目录
SYS_MYSQL_USER = extmail
SYS_MYSQL_PASS = extmail
以上两句句用来设置连接数据库服务器所使用用户名、密码和邮件服务器用到的数据库
SYS_MYSQL_HOST = localhost 指明数据库服务器主机名
SYS_MYSQL_SOCKET = /tmp/mysql.sock 连接数据库的 sock 文件位置
SYS_MYSQL_TABLE = mailbox
SYS_MYSQL_ATTR_USERNAME = username
SYS_MYSQL_ATTR_DOMAIN = domain
SYS_MYSQL_ATTR_PASSWD = password
以上用来指定验正用户登录里所用到的表,以及用户名、域名和用户密码分别对应的表中列的名称
SYS_AUTHLIB_SOCKET = /usr/local/courier-authlib/var/spool/authdaemon/socket
指明 authdaemo socket 文件的位置
apache 相关配置
[root @test root] # vi /usr/local/apache/conf/httpd.conf
将 User daemon
Group daemon
改为
User postfix
Group postfix
将 Include conf/extra/httpd-vhosts.conf
前的注释去掉,打开 apache 的虚拟主机功能。
# virtual hosts
Include conf/extra/httpd-vhosts.conf
vi /usr/local/apache/conf/extra/httpd-vhosts.conf
<VirtualHost *:80>
ServerName mail.wlq.com
DocumentRoot /var/www/extsuite/extmail/html/
ScriptAlias /extmail/cgi /var/www/extsuite/extmail/cgi
Alias /extmail /var/www/extsuite/extmail/html
</VirtualHost>
<Directory "/var/www/extsuite">
Options Indexes FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all
</Directory>
11、安装 Unix-Syslog-1.1.tar.gz和DBD-mysql-2.9008.tar.gz
extmail 将会用到 perl 的 DBD::Mysql 和 Unix::syslogd 功能, 您可以去http://search.cpan.org下载
tar -zxvf Unix-Syslog-1.1.tar.gz
cd Unix-Syslog-1.1
perl Makefile.PL
make
make install
tar –xvzf DBD-mysql-2.9008.tar.gz
cd DBD-mysql-2.9008
perl Makefile.PL
make && make install
到此为止,Webmail 已经可以使用了,可以在浏览器中输入指定的虚拟主机的 名称进行访问,http://mail.wlq.com (做测试可以事先在机子上解析这个域名,加到hosts,也可以搭个dns)
12、安装extman-0.2.5.tar.gz
tar –xvzf extman-0.2.5.tar.gz
mv extman-0.2.5 /var/www/extsuite/extman
vi /var/www/extsuite/extman/webman.cf (修改后的选项)
SYS_MAILDIR_BASE = /var/mailbox/
SYS_MYSQL_SOCKET = /tmp/mysql.sock
使用 extman 源码目录下 docs 目录中的 extmail.sql 和 init.sql 建立数据库:
cd /var/www/extsuite/extman/docs
/usr/local/mysql/bin/mysql -u root < extmail.sql
/usr/local/mysql/bin/mysql -u root -p < init.sql
Enter password: 输入 mysql root 用户的密码
修改 cgi 目录的属主:
chown -R postfix.postfix /var/www/extsuite/extman/cgi/
如果 extman 访问数据库权限不足的话,可采用以下命令将新生成的数据库赋予 webman
/usr/local/mysql/bin/mysql
mysql> use extmail;
mysql> GRANT all privileges on extmail.* TO webman@localhost IDENTIFIED BY 'webman';
mysql> GRANT all privileges on extmail.* TO webman@127.0.0.1 IDENTIFIED BY 'webman';
mysql> quit
在 apache 的虚拟主机配置文件中 Extmail 的虚拟主机部分,再添加如下两行:
vi /usr/local/apache/conf/extra/httpd-vhosts.conf
ScriptAlias /extman/cgi /var/www/extsuite/extman/cgi
Alias /extman /var/www/extsuite/extman/html
启动所有服务: (已启动的可以重启下)
service mysqld start
/usr/local/apache/bin/apachectl start
service courier-authlib start
service imapd start
postfix start
在 IE 浏览器中输入http://mail.wlq.com/extman ,进入邮件服务器的后台,添加域与添加 用户邮箱。默认管理帐号为:root@extmail.org 密码为:extmail*123*。我这里添加了一 个 wlq.com 域和一个用户邮箱:ceshi@wlq.com。至于开通邮件服务器自动注册邮箱服务,只需要编辑该域,将"允许自由注册邮箱"前面打上勾即可。
第一次登录可能出现如下错误:
这是由于 /tmp/extman 目录的原因,新建之即可,然后将该目录权限设置为 777
(1) 如果您安装后无法正常显示校验码,安装 perl-GD 模块会解决这个问题。如果想简单您 可 以 到 以 下 地 址 下 载 适 合 您 的包 , 安 装平 台 的 rpm即可 http://dries.ulyssis.org/rpm/packages/perl-GD/info.html (我用的perl-GD-2.35-1.el5.rf.i386.rpmperl-GD-2.35-1.el5.rf.i386.rpm)
(2) extman-0.2.2 自带了图形化显示日志的功能;此功能需要 rrdtool 的支持,您需要安装
这些模块才可能正常显示图形日志。
接下来安装图形日志的运行所需要的软件包 Time::HiRes、File::Tail 和 rrdtool,其中前两个
包 您 可 以 去 http://search.cpan.org 搜 索 并 下 载 获 得 , 后 一 个 包 您 可 以 到 http://oss.oetiker.ch/rrdtool/pub/?M=D 下载获得; 注意安装顺序不能改换。
下面安装 Time::HiRes 、File::Tail 和 rrdtool
tar zxvf Time-HiRes-1.9721.tar.gz
cd Time-HiRes-1.9721
perl Makefile.PL
make
make test
make install
tar zxvf File-Tail-0.99.3.tar.gz
cd File-Tail-0.99.3
perl Makefile.PL
make
make test
make install
在安装 rrdtool 之前,就确定你的系统中是否已经安装 tcl、tcl-devel、libart、libart-devel
tar zxvf rrdtool-1.2.23.tar.gz
cd rrdtool-1.2.23
./configure --prefix=/usr/local/rrdtool
make
make install
创建必要的符号链接(Extman 会到这些路径下找相关的库文件)
ln –s /usr/local/rrdtool/lib/perl/5.8.8/i386-linux-thread-multi/auto/RRDs/RRDs.so /usr/lib/perl5/5.8.5/i386-linux-thread-multi/
ln -sv /usr/local/rrdtool/lib/perl/5.8.8/RRDp.pm /usr/lib/perl5/5.8.8
ln -sv /usr/local/rrdtool/lib/perl/5.8.8/i386-linux-thread-multi/RRDs.pm /usr/lib/perl5/5.8.8
复制 mailgraph_ext 到/usr/local,并启动
cp -r /var/www/extsuite/extman/addon/mailgraph_ext /usr/local
/usr/local/mailgraph_ext/mailgraph-init start
/usr/local/mailgraph_ext/qmonitor-init start
添加到自动启动
echo "/usr/local/mailgraph_ext/mailgraph-init start" >> /etc/rc.local
echo "/usr/local/mailgraph_ext/qmonitor-init start" >> /etc/rc.local
接下来就可以到 extman里面的全部东西了
http://mail.wlq.com/extman
测试:在web界面中收信,发信都正常,用telnet测试下smtp和pop3
用户名:ceshi@wlq.com 密码:ceshi
用下列命令获得BASE64 编码
[root@mail ~]# perl -e 'use MIME::Base64;print encode_base64("ceshi\@wlq.com")'
Y2VzaGlAd2xxLmNvbQ==
[root@mail ~]# perl -e 'use MIME::Base64;print encode_base64("ceshi")'
Y2VzaGk=
telnet localhost 25
Trying 127.0.0.1...
Connected to wlq.com (127.0.0.1).
Escape character is '^]'.
220 Welcome to our mail.wlq.com ESMTP,Warning:Version not Available!
ehlo mail.wlq.com
250-mail.wlq.com
250-PIPELINING
250-SIZE 14336000
250-VRFY
250-ETRN
250-AUTH PLAIN LOGIN
250-AUTH=PLAIN LOGIN
250-ENHANCEDSTATUSCODES
250-8BITMIME
250 DSN
auth login
334 VXNlcm5hbWU6
Y2VzaGlAd2xxLmNvbQ==
334 UGFzc3dvcmQ6
Y2VzaGk=
235 2.0.0 Authentication successful
quit
221 2.0.0 Bye
Connection closed by foreign host.
telnet localhost 110
Trying 127.0.0.1...
Connected to wlq.com (127.0.0.1).
Escape character is '^]'.
+OK Hello there.
user ceshi@wlq.com
+OK Password required.
pass ceshi
+OK logged in.
quit
+OK Bye-bye.
Connection closed by foreign host. (上面红色部分为手动输入)
测试authlib
/usr/local/authlib/sbin/authtest -s login ceshi@wlq.com ceshi
Authentication succeeded.
Authenticated: ceshi@wlq.com (uid 2525, gid 2525)
Home Directory: /var/mailbox/wlq.com/ceshi
Maildir: (none)
Quota: (none)
Encrypted Password: $1$Zv/N0qB1$kMAqtkM2L5CiVt8d05FzU/
Cleartext Password: ceshi
Options: (none)
13、安装maildorp-2.0.4.tar.bz2
首先将courier-authlib的头文件及库文件链接至/usr目录(编译maildrop时会到此目录下找此些相关 的文件):
ln -sv /usr/local/authlib/bin/courierauthconfig /usr/bin
ln -sv /usr/local/authlib/include/* /usr/include
maildrop需要pcre的支持,因此,接下来将首先安装pcre
tar jxvf pcre-7.2.tar.bz2
cd pcre-7.2
./configure
make
make check
make install
groupadd -g 1001 vmail
useradd -g vmail -u 1001 -M -s /sbin/nologin vmail
tar jxvf maildrop-2.0.4.tar.bz2
cd maildrop-2.0.4
./configure --enable-sendmail=/usr/sbin/sendmail --enable-trusted-users='root vmail' --enable-syslog=1 --enable-maildirquota --enable-maildrop-uid=1001 --enable-maildrop-gid=1001 --with-trashquota --with-dirsync
make
make install
安装过程中要有这个错误/usr/bin/install: cannot stat `makedat/makedatprog': No such file or directory时,应检查gbdm和gbdm-devel包,安这两包后就可以了
检查安装结果,请确保有"Courier Authentication Library extension enabled."一句出现:
# maildrop -v
maildrop 2.0.4 Copyright 1998-2005 Double Precision, Inc.
GDBM extensions enabled.
[color=DarkOrange]Courier Authentication Library extension enabled.[/color]
Maildir quota extension enabled.
This program is distributed under the terms of the GNU General Public
License. See COPYING for additional information.
vi /etc/maildroprc (新建)
logfile "/var/log/maildrop.log"
touch /var/log/maildrop.log
chown vmail.vmail /var/log/maildrop.log
配置 postfix,
vi /etc/postfix/master.cf
启用下面这两行,将前面的注释符号去掉
maildrop unix - n n - -
pipe flags=DRhu user=vmail argv=/usr/local/maildrop/bin/maildrop -d ${recipient}
vi /etc/postfix/main.cf
将 virtual_transport = virtual 修改为 virtual_transport = maildrop
virtual_uid_maps = static:1001
virtual_gid_maps = static:1001
vi /usr/local/ authlib/etc/authlib/authmysqlrc
下面两个修改为
MYSQL_UID_FIELD ‘1001’
MYSQL_GID_FIELD ‘1001’
vi /usr/local/apache/conf/httpd.conf (下面选项修改为如下的值)
User vmail
Group vmail
修改用户邮件所在目录 /var/mailbox 和 extman 的临时目录 /tmp/extman 的属主和属组
chown -R vmail.vmail /var/mailbox
chown -R vmail.vmail /tmp/extman
重新启动 apache 和 postfix,在web界面发送一份邮件测试,tail -f /var/log/maillog中看到的日志,
Oct 27 09:45:05 mail postfix/pipe[21265]: 71D4C3674EE: to=<ceshi@wlq.com>, relay=maildrop, delay=486, delays=485/0.08/0/0.25, dsn=4.3.0, status=deferred (temporary failure. Command output: /usr/local/bin/maildrop: Unable to open mailbox. )
Oct 27 09:45:35 mail maildrop[21273]: Unable to open mailbox.
报错,在网上找了找,发现在/etc/maildroprc中少了一行,加了这行,测试就OK
[root@mail mailbox]# vi /etc/maildroprc
logfile "/var/log/maildrop.log"
to "$HOME/Maildir" (新加的一行)
再测试:tail –f /var/log/maillog
Oct 27 09:47:16 mail postfix/pipe[21306]: 8D2D03674F9: to=<ceshi@wlq.com>, relay=maildrop, delay=0.96, delays=0.2/0.05/0/0.7, dsn=2.0.0, status=sent (delivered via maildrop service)
Oct 27 09:47:16 mail postfix/qmgr[20843]: 8D2D03674F9: removed
[root@mail mailbox]# tail -f /var/log/maildrop.log
Date: Wed Oct 27 09:46:33 2010
From:
Subj:
File: /var/mailbox/wlq.com/ceshi/Maildir
测试成功,说明Maildrop安装成功,到此为止,邮件系统的搭建基本完成,接下来安装反病毒和反垃圾邮件的相关组件,下篇接着弄。
非常感谢网上搭建邮件系统的前辈们,这也是根据他们的文档自己做了一次搞下来的,同时自己在做的过程中也记录下做个备份。
参考:http://bbs.chinaunix.net/archiver/tid-1419582.html
http://sery.blog.51cto.com
http://blog.5ilinux.com/archives/mail/
转载于:https://blog.51cto.com/wanglq/412465