Linux 版 (精华区)

发信人: netiscpu (说不如做), 信区: Linux
标  题: Qmail简介
发信站: 哈工大紫丁香 (Tue May 18 08:31:40 1999), 转信

NJLUG 1998.12.26 LinuXmas联谊会 征文比赛 参赛作品 

Qmail

1 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 <me@domain> 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 <me@domain> 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 <me@domain> 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 <me@domain> 

       250 ok 

       rcpt <me@domain> 

       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 

    这样所有发往me@your.virtual.domains都将以youracct-me@your.virtual.domai

ns     的形式发给youracct,配合procmail和fetchmail,可以方便的分捡进行再投递.

 

以上配置方法都可以在qmail的FAQ中找到. 

  

  

  

---------------------------------------------------------------------------

-----

版权所有 (C) 1998 NJLUG

出版于1998年12月 中文版第二期

---------------------------------------------------------------------------

-----


--
☆ 来源:.哈工大紫丁香 bbs.hit.edu.cn.[FROM: bin@mtlab.hit.edu.cn]
[百宝箱] [返回首页] [上级目录] [根目录] [返回顶部] [刷新] [返回]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:2.412毫秒