当前位置:Linux教程 - Linux - Qmail简介

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公报