由于更换服务器,因此重建了邮件服务器。
相关网站:
- qmail ( http://www.qmail.org );
- qmail-smtpd-auth (smtp验证模块)(
http://members.elysium.pl/brush/qmail-smtpd-auth/ ); - ucspi-tcp 和 daemontools ( http://cr.yp.to/software.html );
- vpopmail ( http://sourceforge.net/projects/vpopmail/
);
下载所需的源文件(如果下载不了,可能是已经有了升级,那么就需要到这些网站上去下载了):
- qmail ( http://www.qmail.org/netqmail-1.05.tar.gz
); - qmail-smtpd-auth (
http://members.elysium.pl/brush/qmail-smtpd-auth/dist/ 到这个页面下载最新的版本 ); - ucspi-tcp ( ftp://cr.yp.to/ucspi-tcp/ucspi-tcp-0.88.tar.gz
); - daemontools ( ftp://cr.yp.to/daemontools/daemontools-0.76.tar.gz
); - vpopmail ( http://sourceforge.net/projects/vpopmail/
到这个页面查看下载最新版本);
解压
- qmail
- tar xvfz
netqmail-1.05.tar.gz - cd netqmail-1.05
- ./collate.sh (1.05后,需要在解压后执行这个文件)
- tar xvfz
- qmail-smtpd-auth
- tar xvfz qmail-smtpd-auth-0.31.tar.gz
- cp README.auth base64.c base64.h ../netqmail-1.05/netqmail-1.05
- patch -d ../netqmail-1.05/netqmail-1.05 < auth.patch #给qmail-smtpd.c打补丁
- ucspi-tcp
- tar xvfz ucspi-tcp-0.88.tar.gz
- daemontools
- mkdir -p /package
- mv daemontools-0.76.tar.gz /package
- tar xvfz daemontools-0.76.tar.gz
- vpopmail
- tar xvfz vpopmail-5.4.9.tar.gz
安装qmail
- qmail
- mkdir /var/qmail
- 建立qmail用户和用户组,见 附录1
- make setup check
- ./config (如果不成功,使用 ./config-fast the.full.hostname )
- ucspi-tcp
- patch < /usr/src/netqmail-1.05/other-patches/ucspi-tcp-0.88.errno.patch
- make
- make setup check
- daemontools
- cd src
- patch < /usr/src/netqmail-1.05/other-patches/daemontools-0.76.errno.patch
- cd ..
- package/install
设置qmail (请注意在安装vpopmail前的设置和附录中的文件,和在安装vpopmail后,会有所变化)
- 建立文件:/var/qmail/rc,见附录2
- chmod 755 /var/qmail/rc
- mkdir /var/log/qmail
- echo ./Mailbox >/var/qmail/control/defaultdelivery
- 建立启动文件:
- /var/qmail/bin/qmailctl (qmail运行控制文件)见附录3
- chmod 755 /var/qmail/bin/qmailctl (赋可执行权限)
- ln -s /var/qmail/bin/qmailctl /usr/bin (在bin中建立链接,运行时不用输入完整路径)
- mkdir -p /var/qmail/supervise/qmail-send/log (发送日志执行文件目录)
- mkdir -p /var/qmail/supervise/qmail-smtpd/log
(smtp登陆日志执行目录) - 建立文件 /var/qmail/supervise/qmail-send/run
(启动发送邮件文件)见附录4 - 建立文件 /var/qmail/supervise/qmail-send/log/run (发送日志运行文件) 见附录5
- 建立文件 /var/qmail/supervise/qmail-smtpd/run (smtp进程启动文件) 见附录6
- echo 20 > /var/qmail/control/concurrencyincoming (并发数量)
- chmod 644 /var/qmail/control/concurrencyincoming (改变属性)
- 建立文件 /var/qmail/supervise/qmail-smtpd/log/run (smtp日志执行文件) 见附录7
- chmod 755 /var/qmail/supervise/qmail-send/run (赋予可执行权限)
- chmod 755 /var/qmail/supervise/qmail-send/log/run
- chmod 755 /var/qmail/supervise/qmail-smtpd/run
- chmod 755 /var/qmail/supervise/qmail-smtpd/log/run
- mkdir -p /var/log/qmail/smtpd (建立smtp登陆日志文件保存目录)
- chown qmaill /var/log/qmail /var/log/qmail/smtpd (改变目录所有者)
- ln -s /var/qmail/supervise/qmail-send /var/qmail/supervise/qmail-smtpd /service (建立链接,以便守护进程启动它们)
- echo '127.:allow,RELAYCLIENT=""' >>/etc/tcp.smtp (建立smtp允许规则)
- qmailctl cdb (为smtp重建tcpserver cdb文件)
- mkdir -p /var/qmail/supervise/qmail-pop3d/log (建立pop3日志执行文件目录)
- 建立文件 /var/qmail/supervise/qmail-pop3d/run (pop3启动文件) 见附录9
- 建立文件 /var/qmail/supervise/qmail-pop3d/log/run (pop3日志执行文件) 见附录10
- mkdir /var/log/qmail/pop3d (建立pop3日志保存目录)
- chown qmaill /var/log/qmail/pop3d (改变目录所有者)
- chmod 755 /var/qmail/supervise/qmail-pop3d/run (赋予run可执行权限)
- chmod 755 /var/qmail/supervise/qmail-pop3d/log/run
- ln -s /var/qmail/supervise/qmail-pop3d /service (建立链接,以便守护进程启动它)
- 修改 qmailctl 文件内容,添加了pop3部分的完整内容 见附录11
- 删除sendmail,及建立链接到qmail
- mv /usr/lib/sendmail /usr/lib/sendmail.old
# ignore errors - mv /usr/sbin/sendmail /usr/sbin/sendmail.old
# ignore errors - chmod 0 /usr/lib/sendmail.old /usr/sbin/sendmail.old
# ignore errors - ln -s /var/qmail/bin/sendmail /usr/lib
- ln -s /var/qmail/bin/sendmail /usr/sbin
- mv /usr/lib/sendmail /usr/lib/sendmail.old
- 建立系统级别名
- echo
your-name > /var/qmail/alias/.qmail-root - echo your-name > /var/qmail/alias/.qmail-postmaster
- ln -s .qmail-postmaster /var/qmail/alias/.qmail-mailer-daemon
- chmod 644 /var/qmail/alias/.qmail-root /var/qmail/alias/.qmail-postmaster
- echo
启动qmail
- # qmailctl start
测试qmail
- # qmailctl stat 执行后应看到以下信息:
/service/qmail-send: up (pid 30303) 187 seconds
/service/qmail-send/log: up (pid 30304) 187 seconds
/service/qmail-smtpd: up (pid 30305) 187 seconds
/service/qmail-smtpd/log: up (pid 30308) 187 seconds
messages in queue: 0
messages in queue but not yet preprocessed: 0 - 建立文件 inst_check,见附录8
- 执行命令:sh inst_check,如果成功,则有如下提示:
Congratulations, your LWQ installation looks good! - ps -efl | grep "service errors" | grep -v grep 会看到类似下面的信息:
4 S root3878 3866 0 85 0 - 305 pipe_w 15:14 ? 00:00:00 readproctitle service errors: ........... - 如果“......."后面没有内容,那就说明正确,如果有内容,则是错误提示
- 添加了 pop3 部分的 qmailctl 查看的状态是:
/service/qmail-send: up (pid 4119) 513 seconds
/service/qmail-send/log: up (pid 4132) 513 seconds
/service/qmail-smtpd: up (pid 4120) 513 seconds
/service/qmail-smtpd/log: up (pid 4133) 513 seconds
messages in queue: 0
messages in queue but not yet preprocessed: 0
/service/qmail-pop3d: up (pid 5176) 1 seconds
/service/qmail-pop3d/log: up (pid 4134) 513 seconds - 到这里qmail安装成功,下面安装设置vpopmail
vpopmail 安装及配置
- 准备
- 新建用户 vpopmail 和 用户组 vchkpw ,大多数用都会把 uid 和 gid 设定为89,这个其实无所谓,其实脚本里完全可以不需要这个,加个获得uid和gid的代码就可以了。所以这里说uid和gid,你不用去太关心。
- 而你要关心的是 vpopmail 这个用户的用户根目录设定在哪里?
- 如果你已经为保存邮件而设定了一个分区,那么就把vpopmail的用户根目录设定为这个分区。
- 如果没有,建议设定到一个比较大的相对独立的分区,如果可以,不要设定在home分区,因为保存邮件的分区随着邮件服务器运行会不断的产生大量磁盘碎片,这会非常影响home分区中其它用户的使用的性能。
- 安装
- 添加用户vpopmail和用户组vchkpw,当然,可以使用任何添加用户和用户组的方法新建它们,这里给出的是命令行方式:
- groupadd -g 89 vchkpw
- useradd -g vchkpw -u 89 -d /home/vpopmail vpopmail
- mkdir ~vpopmail/etc (建立etc目录)
- chown vpopmail.vchkpw ~vpopmail/etc
(改变所属用户和组) - echo "localhost|0|vpopmailuser|vpoppasswd|vpopmail" > ~vpopmail/etc/vpopmail.mysql
(建立vpopmail链接MySQL数据库的配置文件) - chown vpopmail.vchkpw ~vpopmail/etc/vpopmail.mysql
(改变所属用户和组) - chmod 640 ~vpopmail/etc/vpopmail.mysql
(修改文件属性) - 在 MySQL 中建立一个用户:vpopmail,不要给这个用户任何权限
- 在 MysQL 中建立一个数据库:vpopmail
- 在 MySQL 中设定数据库权限,将数据库vpopmail只运行vpopmail这个用户访问,权限设定为:select,insert,update,delete,create,drop 。
- 配置vpopmail (配置选项扼要解释:关闭了登陆pop3后可发送smtp的功能,因为我们的qmail安装了smtp验证;关闭了邮箱容量限制;校验模块使用MySQL;打开别名功能)
./configure --disable-roaming-users --enable-logging=p --disable-passwd --enable-clear-passwd --disable-domain-quotas --enable-auth-module=mysql --disable-many-domains --enable-auth-logging --enable-sql-logging --enable-valias --disable-mysql-limits - 编译和安装
make
make install-strip - 如果你想设定邮箱容量限制,那么修改 vlimits.default:
vi ~vpopmail/etc/vlimits.default
# in particular set the default mailbox size to be something reasonable eg 20Mb
default_quota 20971520 (修改这个内容,默认的是20M) - 设定默认域(这个问题,有的人说没必要,我认为有必要,这样对主域来说,在客户端就不需要在用户名处输入全部邮件地址了。)
echo "yourdomain.com" > ~vpopmail/etc/defaultdomain - 设定邮箱内邮件总容量达到邮箱限制的90%的提示内容文件
~vpopmail/domains/.quotawarn.msg 见附录12 - 设定邮箱已满的提示信息内容(写中文也可以,不过如果客户端不一定能正常显示,所以还是写英文吧)
echo "Message rejected. Not enough storage space in user's mailbox to accept message." > ~vpopmail/domains/.over-quota.msg - 好了vpopmail安装和设定好了。现在要修改 qmail pop3启动内容。就是让qmail的pop3部分使用vpopmail的校验,当然也需要修改smtp部分的内容,是让qmail的smtp验证使用vpopmail的校验。
- 修改文件 /var/qmail/supervise/qmail-pop3d/run 见附录13
- 修改文件 /var/qmail/supervise/qmail-smtpd/run 见附录14
- 重新启动qmail
qmailctl restart - 用telnet方式来测试:
- 测试 pop3 的命令(橙色部分为系统显示内容):
# telnet localhost 110
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
+OK 4047.1110877290@your-domain-address
user your-email-user-name
+OK
pass your-email-user's-password
+OK
如果输入password后显示"+OK"那就表示正确! - 测试 smtp 的命令(橙色部分为系统显示内容):
# telnet localhost 25
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
220 your-domain-address ESMTP
HELO
250 your-domain-address
MAIL FROM:user@ your-domain-address
250 ok
RCPT TO:receive-user@ receive-user-domain-address
250 ok
DATA
354 go ahead
Subject: test message
This is a test message
.
250 ok 1110872613 qp 22398 - 用户邮件客户端软件测试。
- 测试 pop3 的命令(橙色部分为系统显示内容):
- 添加用户vpopmail和用户组vchkpw,当然,可以使用任何添加用户和用户组的方法新建它们,这里给出的是命令行方式:
- 维护
- 添加域:~vpopmail/bin/vadddomain your-domain-name
- 添加用户邮箱:~vpopmail/bin/vadduser username@your-domain-name.com
- 删除用户邮箱:~vpopmail/bin/vdeluser username@your-domain-name.com
- 删除域:~vpopmail/bin/vdeldomain your-domain-name
- 修改用户邮箱的密码:~vpopmail/bin/vpasswd username@your-domain-name.com
- 查看用户邮箱信息:~vpopmail/bin/vuserinfo username@your-domain-name.com
- 其它更多的命令,需要查看帮助中的解释和说明
有可能遇到的问题:
- Outlook提示:Server Error: 553, Error Number: 0x800CCC79 错误信息。客户端无法收发信,总是提示用户名和密码错误。
原因:这个很可能是由于softlimit的-m的值过小,导致:vchkpw:error while loading shared libraries:libc.so.6: failed to map segment from shared...。
解决办法:将smtp启动脚本中的softlimit -m 值设置大些。例如设定成4000000(4M)或者更大。 - 如果qmail正确,确总是出现用户名密码错误,这多部分说明是vpopmail验证部分出问题了,仔细检查启动脚本中是否有错误,例如:你可能设定vpopmail用户的用户根目录不是/home/vpopmail,而在脚本中写的是/home/vpopmail,如果是这样,建议你在绝大多数情况下,写成 ~vpopmail。
- Vpopmail 编译安装后,数据库vpopmail中没有增加表等内容。这说明你的MySQL安装有问题,或者是 share模块安装的不正确,解决办法:
- 使用你设定的MySQL中的vpopmail账号进行登陆MySQL以及访问vpopmail数据库的尝试,如果成功,则是MySQL share部分的问题,重新安装它。
- 如果使用该账号不能访问成功,说明MySQL中账号或权限设定有问题。