Qmail简介
1.1 什么是Qmail
Qmail是一种可以完全替代Sendmail-binmail体系的新一代Unix邮件系统.
1.2 为什么选择Qmail?
A. 安全----Qmail将Mail处理过程分为多个分过程,尽力避免用root用户
运行.同时Qmail也禁止对特权用户(root,deamon等等)直接发
信.
B. 可靠----Qmail的直接投递保证Email在投递过程中不会丢失.Qmail同时支持
新的更可靠的信箱格式Maildir,保证系统在突然崩溃情况下不至
破坏整个信箱.
C. 高效----在运行于奔腾的BSD/OS上,Qmail每天可以轻松的投递200000
封信件.
D. 简单----Qmail要比其他的Internet Mail系统小得多.Qmail通过统一的
向前机制完成forwarding,alias和maillist等功能,Qmail使用
简单高效队列来处理投递.Qmail-smtpd可以由inetd启动,节省
了一定资源.
Qmail支持: host and user masquerading
full host hiding
virtual domains
null clients
list-owner rewriting
relay control
double-bounce recording
arbitrary RFC 822 address lists
cross-host mailing list loop detection
1.3 如何获得Qmail?
可以通过访问www.qmail.org或mirror站点下载qmail-1.03.tar.gz,以及获得
更多qmail的资料.
2 安装Qmail
获得qmail-1.03.tar.gz后,用tar命令解包
#tar xzvf qmail-1.03.tar.gz
进入qmail目录后,仔细阅读一下README和INSTALL文件.然后开始编译qmail.
2.1 建/var/qmail目录:
#mkdir /var/qmail
2.2 按照INSTALL.ids中方法建立qmail用户和组:
# groupadd nofiles
# useradd -g nofiles -d /var/qmail/alias alias
# useradd -g nofiles -d /var/qmail qmaild
# useradd -g nofiles -d /var/qmail qmaill
# useradd -g nofiles -d /var/qmail qmailp
# groupadd qmail
# useradd -g qmail -d /var/qmail qmailq
# useradd -g qmail -d /var/qmail qmailr
# useradd -g qmail -d /var/qmail qmails
2.3 make setup check
2.4 阅读INSTALL.ctl和FAQ,配置qmail,最简单的方法是
#./config
或者
#./config-fast your.full.home.name
2.5 建立系统别名
# (cd ~alias; touch .qmail-postmaster .qmail-mailer-daemon .qmail-root)
# chmod 644 ~alias/.qmail*
2.6 复制/var/qmail/boot/proc到/var/qmail/rc
# cp /var/qmail/boot/proc /var/qmail/rc
2.7 开始测试Qmail投递程序
启动qmail:
# csh -cf \/var/qmail/rc &\
先查看一下/var/log/maillog,搜索
qmail: status: local 0/10 remote 0/20
qmail-send通常是输出\"status\"或者\"cannot start\"如果不能正常启动.
用ps监视一下qmail守护进程,应该有五个相关进程:
qmail-send,以qmails用户运行
qmail-lspawn,以root用户运行
qmail-rspawn,以qmailr用户运行
qmail-clean,以qmailq用户运行
splogger,以qmaill用户运行
本地Mail测试:
% echo to: me | /var/qmail/bin/qmail-inject
注意:要用你的用户名代替me
Mail应该立即出现在你的信箱之中./var/log/maillog中应该有如下记录:
qmail: new msg 53
qmail: info msg 53: bytes 246 from qp 20345 uid 666
qmail: starting delivery 1: msg 53 to local me@domain
qmail: status: local 1/10 remote 0/20
qmail: delivery 1: success: did_1+0+0/
qmail: status: local 0/10 remote 0/20
qmail: end msg 53
53是inode号,20345是进程号,你的数字应该有所不同.
本地错误测试:
给一个不存在的本地用户发信:
% echo to: nonexistent | /var/qmail/bin/qmail-inject
qmail: new msg 53
qmail: info msg 53: bytes 246 from qp 20351 uid 666
qmail: starting delivery 2: msg 53 to local nonexistent@domain
qmail: status: local 1/10 remote 0/20
qmail: delivery 2: failure: No_such_address.__#5.1.1_/
qmail: status: local 0/10 remote 0/20
qmail: bounce msg 53 qp 20357
qmail: end msg 53
qmail: new msg 54
qmail: info msg 54: bytes 743 from <> qp 20357 uid 666
qmail: starting delivery 3: msg 54 to local me@domain
qmail: status: local 1/10 remote 0/20
qmail: delivery 3: success: did_1+0+0/
qmail: status: local 0/10 remote 0/20
qmail: end msg 54
你将立即收到弹回的信件.
远程投递测试: 向你在其他机器上的账户发信:
% echo to: me@wherever | /var/qmail/bin/qmail-inject
qmail: new msg 53
qmail: info msg 53: bytes 246 from qp 20372 uid 666
qmail: starting delivery 4: msg 53 to remote me@wherever
qmail: status: local 0/10 remote 1/20
qmail: delivery 4: success: 1.2.3.4_accepted_message./...
qmail: status: local 0/10 remote 0/20
qmail: end msg 53
投递过程将在starting delivery和success中有个间断,SMTP传送是相对较慢的
然后去检查一下me@wherever是否正确收到email.
后面还有三个测试,分别测试本地postmaster,两次弹回mail和通过mail执行
命令.具体方法可以在TEST.deliver中找到.
2.8 从Sendmail象Qmail转移.
2.8.1 首先找到sendmail的启动程序,一般是在/etc/rc.d目录中
看上去象这样的命令:
sendmail -bd -q15m
将其注释掉.
2.8.2 杀掉Sendmail进程.
如果sendmail有子进程,可以反复用-STOP和-CONT信号杀,直到没有
子进程后用-TERM后加-CONT杀就可以了.
2.8.3 检查mail队列中是否还有信,如果认为有必要将他们发送出去,可以在
以后一段时间不定期的运行sendmail.bak -q直到队列清空.
2.8.4 去掉sendmail等文件的setuid bit
# chmod 0 /usr/lib/sendmail
# chmod 0 /usr/sbin/sendmail
# chmod 0 /usr/lib/sendmail.mx
2.8.5
# mv /usr/lib/sendmail /usr/lib/sendmail.bak
# mv /usr/sbin/sendmail /usr/sbin/sendmail.bak
2.8.6 将
csh -cf \/var/qmail/rc &\
添加到启动文件中去.
2.8.7 安装qmail的sendmail外壳:
# ln -s /var/qmail/bin/sendmail /usr/lib/sendmail
# ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail
2.8.8 在/etc/inetd.conf中设置qmail-smtpd:(是一行)
smtp stream tcp nowait qmaild /var/qmail/bin/tcp-env
tcp-env /var/qmail/bin/qmail-smtpd
2.8.9 重启动inetd,用-HUP信号杀inetd及可.
2.8.10 进行收信测试:仔细阅读TEST.receive
2.8.10.1 SMTP Server测试,me是你的用户,domain是你的机器名.
% telnet 127.0.0.1 25
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is \^]\.
220 domain ESMTP
helo dude
250 domain
mail
250 ok
rcpt
250 ok
data
354 go ahead
Subject: testing
This is a test.
.
250 ok 812345679 qp 12345
quit
221 domain
Connection closed by foreign host.
看看信箱中是否有新信.
2.8.10.2 从其他机器上发信给me@domain,看看是否能正确接收.
后面还有三个测试:远程错误测试,UA测试和远程PostMaster
测试,具体方法可以参照TEST.receive
如果以上都没有问题,Qmail就算基本安装成功.
3 qmail的一些特殊配制
3.1 如何设置Smart Host:
# echo \":your.smart.host\" > /var/qmail/control/smtproutes
3.2 如何设置允许转信:
将/etc/inetd.conf中smtp服务做如下修改:
smtp stream tcp nowait qmaild /usr/local/bin/tcpd
/var/qmail/bin/tcp-env /var/qmail/bin/qmail-smtpd
然后阅读tcpwarpper相关文档,在/etc/hosts.allow中加入
tcp-env: 1.2.3.4, 1.2.3.5: setenv = RELAYCLIENT
1.2.3.4和1.2.3.5是你的客户机ip地址,也可以使用tcpwarpper
的所允许的其他地址形式.
3.3 如何设置虚拟主机
将虚拟主机名入/var/qmail/control/local和/var/qmail/control/rcpthosts
然后在/var/qmail/control/virtualdomains中加入
your.virtual.domains:youracct
这样所有发往[email protected]ins都将以[email protected]ins
的形式发给youracct,配合procmail和fetchmail,可以方便的分捡进行再投递.
以上配置方法都可以在qmail的FAQ中找到.
发布人:netbull 来自:Linxu公报