一:适用范围:
本文探讨的是如何建立一个可容纳数K-数M数量级用户的邮件系统,实现如此大量的用户,使我们有充足的理由弃sendmail,转向qmail,如果你的系统仅仅需要为几十用户提供mail服务,那么你应该使用sendmail,为转向qmail并不是一件轻松的工作。
二:想达到的目的:
假设你有了一台运行RedHat 7.1 的系统,DNS工作正常,特别是,MX纪录正确。现在希望在此系统上实现一个ail Server,要求:
1:支持可预见的用户数量;
2:多域(不同于你的主机域)
3:管理简洁;
4:在线申请账号;
5:全功能的Web界面支持;
6:pop3及smtp(验证)支持;
………………
三:所需软件包:
许多人安装qmail是从qmail-1.03.tar.gz源码包开始的,虽然可定制,但得到一个可运行的qmail时(假设每步都不出意外),已经耗去了你的大部分精力与热情,网上大部分qmail的文章从头到尾都是教你如何去编辑种各样的启动脚本,如何configure。实际上,qmail的安装已相当成熟,没有必要再重复别人已经做过的工,因此,本文主要使用.src.rpm包来构建系统(qmail不允许第三方以二进制发行)。
1:基本系统
ucspi-tcp-0.88-1.src.rpm
ucspi-unix-0.34-1.src.rpm
daemontools-0.70-3.src.rpm
supervise-scripts-3.3-1.src.rpm
qmail-1.03_252bpatches-18.src.rpm
以上包均由Dan Kuykendall发行,可在http://untroubled.org/或http://em.ca/~bruceg/找到。
2:www.Inter7.com的系列包:
vpopmail-4.10.26.tar.gz
qmailadmin-0.56.tar.gz
sqwebmail-2.1.1.tar.gz
3:依附包
autorespond-1.0.0.tar.gz
ezmlm-0.53.tar.gz
ezmlm-idx-0.40.tar.gz
maildrop-1.3.3.tar.gz
四:安装qmail
1:
rpm --rebuild ucspi-tcp-0.88-1.src.rpm
rpm --rebuild daemontools-0.70-3.src.rpm
rpm --rebuild supervise-scripts-2.4-1.src.rpm
rpm -rebiuld ucspi-unix-0.34.src.rpm
2:
rpm -ivh /usr/src/redhat/RPMS/i386/ucspi-tcp-0.88-1.i386.rpm
rpm -ivh /usr/src/redhat/RPMS/i386/ucspi-unix-0.34.i386.rpm
rpm -ivh /usr/src/redhat/RPMS/i386/daemontools-0.70-3.i386.rpm
rpm -ivh /usr/src/redhat/RPMS/noarch/supervise-scripts-2.4-1.noarch.rpm
5:rpm -e --nodeps sendmail
6:
rpm -rebiuld qmail-1.03_252bpatches-18.src.rpm
rpm -ivh /usr/src/redhat/RPMS/i386/qmail-1.03+patches-18.i386.rpm
7:config
(replace 192.168.2 with your own IP,replace hleil with your own user name)
echo "127.allow" >> /etc/tcpcontrol/pop-3.rules
echo "192.168.2.allow" >> /etc/tcpcontrol/pop-3.rules
echo '127.allow,RELAYCLIENT=""' >> /etc/tcpcontrol/smtp.rules
echo '192.168.2.allow, RELAYCLIENT=""' >> /etc/tcpcontrol/smtp.rules
tcprules /etc/tcpcontrol/pop-3.cdb /etc/tcpcontrol/pop-3.tmp
< /etc/tcpcontrol/pop-3.rules
tcprules /etc/tcpcontrol/smtp.cdb /etc/tcpcontrol/smtp.tmp
< /etc/tcpcontrol/smtp.rules
echo hleil > /etc/qmail/alias/.qmail-root
8:Start pop3 and smtp:
killall -HUP init
svc-add /var/qmail/service/pop3d
svc-add /var/qmail/service/smtpd
OK!基本的qamil系统已安装完毕,够简单吧!root的邮件将发往hleil。
要是你还嫌麻烦,我编辑了一个脚本qmail-1.03-18,修改一下,执行:
./qmail-1.03-18 install
就行了!
安装脚本请到此下载!
9:说明
本qmail没有auto-create-Maildir-when-a message arrived 功能,需手工为用户建立Maildir,使用此脚本来转换mailbox->Maildir并为每个系统用户建立Maildir!
五:虚拟域支持(vpopmail):
1:确保mysql运行正常,添加用户vpopmail,vpopmailread,vpopmail拥有全部权限,用于创建及管理,vpopmailread只可select,用于vpopmail的日常运行。要为vpopmail设定default-domain。实在无此必要。并可能带来不必要的麻烦。
2:tar- zxvf vpopmail-4.10.24.tar.gz
3:
cd vpopmail-4.10.24
echo '#define MYSQL_UPDATE_SERVER "localhost"' >> vmysql.h
echo '#define MYSQL_UPDATE_USER "vpopmail"' >> vmysql.h
echo '#define MYSQL_UPDATE_PASSWD "vpopmailadmin"' >> vmysql.h
echo '#define MYSQL_READ_SERVER "localhost"' >> vmysql.h
echo '#define MYSQL_READ_USER "vpopmailread"' >> vmysql.h
echo '#define MYSQL_READ_PASSWD "vpopmailread"' >> vmysql.h
创建vchkpw组及vpopmail用户
./configure --enable-auth-logging=y --enable-logging=v
--enable-log-name=vpopmail
--enable-mysql=y --enable-roaming-users=y
--enable-harkdquota=20000000 --enable-sqwebmail-pass=n
--enable-many-domains=n --enable-passwd=y
--enable-tcpserver-file=/etc/tcpcontrol/smtp.rules
--enable-sqlincdir=/usr/include/mysql --enable-sqllibdir=/usr/lib/mysql
--enable-sqllibs=mysqlclient
--enable-ip-alias-domains=y --enable-qmail-ext=y
--enable-hardquota=20000000 --enable-mysql-replication=n
--enable-valias=y
make clean
make
make install-strip
(replace "$vpopmailhome" with your realy path)
echo "$vpopmailhome"/bin/vchkpw > /etc/qmail/control/checkpassword
svc-stop /service/pop3d
svc-start /service/pop3d
edit /etc/crontab,add this line(of course replace home-dir-of-vpopmail
with realy path):
40 * * * * /home-dir-of-vpopmail/bin/clearopensmtp 2>&1 > /dev/null
then(非常重要!):
rm -f /etc/cron.hourly/qmail
OK!
安装脚本请到此下载!
4:系统说明:
pop3:用vchkpw代替checkpasswd,本域用户查找/etc/passwd,虚拟域用户查找mysql;
smtp:由于启用了roaming-user,远程用户pop之后,ip自动保存40分钟,此阶段内,用户可用此IP发信。
由于qmail-1.03_252bpatches-18.src.rpm默认安装了一个自动更新/etc/qmail/users/assign及etc/qmail/users/cdb的/etc/cron.hourly/qmail,每小时更新/etc/passwd到etc/qmail/users/cdb,更新过程简单覆盖/etc/qmail/users/assign,若不删除,将导致popmail丢失在/etc/qmail/users/assign及/etc/qmail/users/cdb中的配置。其实对于很少系统户的系统来说,直接查询/etc/passwd并不会导致系统性能下降,因此删除此文件!不必找替代方案(否则要写个脚本代替了)。
六:WEB管理(qmailadmin)
1:为支持vpopmail-4.10.X,必须使用qmailadmin-0.5X。
2:安装autorespond-1.0.0,cp autorespond /usr/local/bin/
3:安装ezmlm-0.53及ezmlm-idx-0.40
4:
tar -zxvf qmailadmin-0.54.tar.gz
cd qmailadmin-0.54
(RedHat 7.1的http主目录有所改变)
mkdir /var/www/qmailadmin
./configure --enable-cgibindir=/var/www/cgi-bin
--with-htmllibdir=/var/www/qmailadmin --enable-htmldir=/var/www
make clean
make
make install-strip
OK!
安装脚本请到此下载!
七:WEB Mail(sqwebmail)
1:为使用vpopmail的vchkpw验证必须使用更新的preauthvchkpw.c文件代替原有文件(必须使用vchkpw证,不能使用mysql验证,Why?因为mysql验证不使用vpopmail的数据,它需要自己建表,哼,标准的圾功能,那个傻子才会用!)。
2:
tar -zxvf sqwebmail-2.1.1.tar.gz
cp -f preauthvchkpw.c sqwebmail-2.1.1/auth
cd sqwebmail-2.1.1
(非常重要!)
INCS=-I/usr/include/mysql
export INCS
LIBS="-L/usr/lib/mysql -lmysqlclient -lz"
export LIBS
CPPFLAGS=-I/usr/include/mysql
LDFLAGS=-L/usr/lib/mysql
export CPPFLAGS
export LDFLAGS
(如果不设定上述环境,make时将出错)
./configure --with-cachedir --without-gzip --enable-webpass=yes
--enable-softtimeout=300 --enable-autopurge=180 --enable-maxpurge=180
--with-htmllibdir=/var/www/sqwebmail --enable-cgibindir=/var/www/cgi-bin
--enable-imagedir=/var/www/images/sqwebmail --enable-imageurl=/images/sqwebmail/
--enable-mimecharset=gb2312 --with-maxargsize=5000000
--with-maxformargsize=5000000 --with-maxmsgsize=5000000 --with-ispell
--with-authshadow --without-authmysql --without-authldap --with-authuserdb
--with-authpwd --without-authpam --with-authvchkpw --without-authdaemon
make configure-check
make
make check
make install-strip
make install-configure
(设定sqwebmail仅用/etc/passwd 和 mysql 的虚拟域信息验证用户,这样本机用户和虚拟域用户都可以用sqwebmail,如果你想更安全,删除authpasswd,仅保留authvchkpw,系统用户将不能通过qwebmail收发邮件)
echo "authvchkpw authpasswd" > /var/www/sqwebmail/authmodulelist
OK!
3:说明
sqwebmail的用户界面可以很容易的定制,并不是说简单的汉化,而是可以创建完全不同的html页面,提是:各页面的头部分必须完整(也就是注释掉的),所有变量不得改动(尤其是大小写)。
我正在做一个简单的汉化,不久可以完成。
八:Bug
本安装过程目前尚未发现Bug,我的测试系统已运行了一周,良好!
如果你发现了更深层次的Bug,请给我发邮件Email:hleil@163.com
九:本文的更新版可在http://hleil.126.com/得到!
参考资料:
1:Qmail-VMailMgr-Courier-imap-HOWTO
2:Vpopmail FAQ
3: Life With qmail
4: Sqwebmail FAQ
Copyright © 2001-2006 GoldStar Studio. All rights reserved.
鲁ICP备11008313号