GoldStar Studio

 Index Next

深入使用qmail+vpopmail+sqwebmail
qmail vpopmail And sqwebmail Howto的最初版本,最初发表于2001年7月3日,在linuxforum.net。这是为了解决工作中的具体问题而形成的一个文档,实用性是它首要考虑的问题。

一:适用范围:

本文探讨的是如何建立一个可容纳数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

Valid XHTML 1.0 StrictCopyright © 2001-2006 GoldStar Studio. All rights reserved.

鲁ICP备11008313号