BBS水木清华站∶精华区

发信人: is (消逝的), 信区: Linux        
标  题: qmail.txt 
发信站: BBS 水木清华站 (Wed May 26 22:08:54 1999) 
 
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.domains   
    的形式发给youracct,配合procmail和fetchmail,可以方便的分捡进行再投递. 
 
以上配置方法都可以在qmail的FAQ中找到. 
 
-- 
※ 来源:·BBS 水木清华站 bbs.net.tsinghua.edu.cn·[FROM: 202.119.79.80] 

BBS水木清华站∶精华区