安装qmail全套功略


作者:wind521
  
  前言
  sendmail的功能是足够强大的,然而它的配置和管理也是十分复杂的。有另一个也很常用的邮件服务程序称为qmail。
  需要注意的是,许多人认为qmail要比sendmail简单一些。就笔者个人的感觉,不能同意这种说法。但是,qmail在配置一些稀奇古怪的功能方面确实比sendmail要稍微容易一 些。另外qmail与sendmail不同之处在于,缺省的时候qmail将在用户的宿主目录中存储邮件,而不是像sendmail那样不分青红皂白地放在/var/spool/mail下面,并且qmail不 需要使用文件锁定,所以可以把用户邮件放在NFS服务器上,这样,可以使用多台服务器 来提供服务。对于大型邮件系统这是很重要的。(在sendmail也可以这样做,但必须非 常小心以免造成邮件丢失)。但是这个功能虽然不错,却又产生了一些十分讨厌的后果 。对于大型的ISP,qmail也很重要,它可以简化虚拟域的设置。我们将试图介绍如何用 qmail构造一个邮件服务器。当然,这里的介绍不可能像介绍sendmail那样细致,如果要 使用一些比较高级的功能,你也许必须研究qmail的文档。
  
  软件包:
  
  qmail-1.03 qmail基本系统。在http://em.ca/~bruceg/qmail+patches/上有一个好的补丁包,里面有若干针对Qmail的POP3d及其他问题的补丁,笔者建议您把它下载过来。
  ucspi-tcp-0.88 tcpsever服务程序
  daemontools-0.70 监视工具
  checkpassword-0.81 pop3验证用户的程序
  ezmlm-0.53 邮件转发
  vpopmail-4.9.6-1 虚拟域用户pop3支持
  qmailadmin-0.35 虚拟域web管理
  autorespond-1.0.0 自动回复程序
  sqwebmail-1.2.0 webmail
  vqsignup-0.4 web方式用户注册
  
  
  软件来源:
  http://www.qmail.org
  http://www.inter7.com/qmail
  每个包安装前务必先仔细阅读INSTALL和FAQ,很多问题在FAQ都有解决方法。
  
  安装步骤:
  
  1. #mkdir /var/qmail
  
  2.设定组、用户权限
   # 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
  
  3.
   #tar xzvf qmail-1.03.tar.gz
  
   进入qmail目录后,仔细阅读一下README和INSTALL文件.然后开始编译qmail
  
   #make setup check
  
  4. #cd qmail-1.03
   #./config
  
  5.建立系统别名
   # (cd ~alias; touch .qmail-postmaster .qmail-mailer-daemon .qmail-root)
   # chmod 644 ~alias/.qmail*
  
  6.
   # cp /var/qmail/boot/home /var/qmail/rc
   # chmod 755 /var/qmail/rc
   编辑 /var/qmail/rc
   修改其中 ./Mailbox 成为 ./Maildir ,如下:
  
   # !/bin/sh
   # Using splogger to send the log through syslog.
   # Using qmail-local to deliver messages to ~/Maildir by default.
   exec env - PATH="/var/qmail/bin:$PATH"
   qmail-start ./Maildir splogger q
  
   其中 splogger qmail 指令是用来将纪录文件纪录于 / 中。
  
  建立样板
  
   $ /var/qmail/bin/maildirmake /etc/skel/Maildir
   $ echo ./Maildir/ > ~/.qmail
  
   注意 Maildir 必须为该使用者所有,可以 chown 变更,并以 chmod 700 Maildir 设定权限。
  
  7.安装 ucspi-tcp-0.88
   # tar zxvf ucspi-tcp-0.88.tar.gz
   # cd ucspi-tcp-0.88
   # make
   # make setup check
   执行档将被安装于 /usr/local/bin 中。
  
  8.安装 checkpassword
   # tar zxvf checkpassword-0.81.tar.gz
   # cd checkpassword-0.81
   # make
   # make setup check
   # chmod og-rx /bin/checkpassword
  
   执行档 checkpassword 将被安装于 /bin 中如果不对/etc/passwd中的用户开放mail,不需要装checkpassword,只要装vpopmail
  
  9.安装 daemontools
  
   # tar zxvf daemontools-0.70.tar.gz
   # cd daemontools-0.70
   # make
   # make setup check
   执行档将安装于 /usr/local/bin 中。安装本工具后可以用
  
   # mkdir /var/run/qmail
   # supervise /var/run/qmail /var/qmail/rc
  
   来启动qmail,可以用svc来关闭活重起qmail,用svstat监视qmail运行情况,(qmail FAQ)
  
  10.安装 vpopmail
  
   # groupadd vchkpw
   # useradd -g vchkpw vpopmail
   # mkdir ~vpopmail/etc
   # echo ":allow" > ~vpopmail/etc/tcp.smtp
   # tar zvfz vpopmail-4.9.6-1.tar.gz
   # cd vpopmail-4.9.6-1
   # ./configure --enable-roaming-users=y --enable-default-domain=mydomain.com --enable-passwd=n
   # make
   # make install-strip
  
   # crontab -e
   40 * * * * /home/vpopmail/bin/clearopensmtp 2>&1 > /dev/null
  
   # cd /home/vpopmail/bin
   # ./vadddomain mydomain.com mydomain
   append mydomain.com to /var/qmail/control/rcpthosts
  
  
  11.从Sendmail向Qmail迁移
  
    如果你的系统以前安装使用着Sendmail,就需要进行下面的步骤:
  
    11.1.首先找到Sendmail的启动程序,一般是在/etc/rc.d目录中,看上去像这样的命令:“sendmail -bd -q15m”,将其注释掉。
  
    11.2. 杀掉Sendmail进程。如果Sendmail有子进程,可以反复用-STOP和-CONT信号杀,直到没有子进程后用-TERM后加-CONT杀就可以了。
  
    11.3. 检查E-mail队列中是否还有信,如果认为有必要将它们发送出去,可以在以后一段时间不定期地运行“sendmail.bak -q”,直到队列清空。
  
    11.4. 去掉Sendmail等文件的setuid bit:
  
    # chmod 0 /usr/lib/sendmail
    # chmod 0 /usr/sbin/sendmail
    # chmod 0 /usr/lib/sendmail.mx
    # mv /usr/lib/sendmail /usr/lib
    /sendmail.bak
    # mv /usr/sbin/sendmail /usr
    /sbin/sendmail.bak
  
    11.5. 将csh -cf ′/var/qmail/rc &&′添加到启动文件中去。
  
    11.6. 安装Qmail的Sendmail外壳:
  
    # ln -s /var/qmail/bin/sendmail /usr/lib/sendmail
    # ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail
  
    11.7. 虚拟域与虚拟用户。
  
    将虚拟域名加入/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。VmailMgr是一个Qmail的增强工具,它扩展了Qmail的口令验证功能,使用户可以通过POP3 及IMAP访问自己的虚拟邮箱,我们将在以后的内容中重点介绍VmailMgr。
  
  12.激活qmail SMTP , POP3 daemon 系统服务
  
   建立 SMTP 转信规则
    建立 /etc/tcp.smtp 内容为
    :allow
   此为接受任何Client端所发出之转送信件
   若要拒绝某些IP所发出之Relay则改为 /etc/tcp.smtp如下
    1.2.3.4:allow,RELAYCLIENT=""
   127.:allow, RELAYCLIENT=""
   如此,除1.2.3.4及127.*之外的所有地址,都将被拒绝转送信件。
     
   接下来,转换 tcp.smtp 成为 cdb 格式。
   # /usr/local/bin/tcprules /etc/tcp.smtp.cdb /etc/tcp.smtp.tmp < /etc/tcp.smtp
  
   注意:若对 tcp.smtp 有任何变更,都必须经过 tcprules 转换成为 cdb 才会生效。另外,tcp.smtp 若为空白,则表示拒绝所有的转送,因为预设的规则为 deny。至此,转送规则已建立,稍后将依此规则激活 qmail-smtpd。
  
    设定 SMTP 及 POP3 daemon 之激活
    请移除 inetd.conf 中有关 smtp 及 pop3 的设定 (加上 # 号)
    编辑 /etc/services,改为以下设定:
  
    smtp 25/tcp mail
   # pop-3 110/tcp #pop version 3
    # pop-3 110/udp
   pop3 110/tcp
    pop3 110/udp
  
    激活 SMTP:
    /usr/local/bin/tcpserver -v -x /etc/tcp.smtp.cdb
    -u UID -g GID 0 smtp /var/qmail/bin/qmail-smtpd 2>&1
    | /var/qmail/bin/splogger smtpd 3 &
  
    其中UID和GID为前述新增 qmail 系统帐号之 qmaild 之 User ID,以及 nofiles 之 group ID。
    /var/qmail/bin/splogger那一行会将log档写在 /var/log/maillog。
  
   激活 POP3:
    编辑激活档加入以下设定:
   tcpserver -H -R 0 pop3
   /var/qma 本文作者:作者:wind521
  
  前言
  sendmail的功能是足够强大的,然而它的配置和管理也是十分复杂的。有另一个也很常用的邮件服务程序称为qmail。
  需要注意的是,许多人认为qmail要比sendmail简单一些。就笔者个人的感觉,不能同意这种说法。但是,qmail在配置一些稀奇古怪的功能方面确实比sendmail要稍微容易一 些。另外qmail与sendmail不同之处在于,缺省的时候qmail将在用户的宿主目录中存储邮件,而不是像sendmail那样不分青红皂白地放在/var/spool/mail下面,并且qmail不 需要使用文件锁定,所以可以把用户邮件放在NFS服务器上,这样,可以使用多台服务器 来提供服务。对于大型邮件系统这是很重要的。(在sendmail也可以这样做,但必须非 常小心以免造成邮件丢失)。但是这个功能虽然不错,却又产生了一些十分讨厌的后果 。对于大型的ISP,qmail也很重要,它可以简化虚拟域的设置。我们将试图介绍如何用 qmail构造一个邮件服务器。当然,这里的介绍不可能像介绍sendmail那样细致,如果要 使用一些比较高级的功能,你也许必须研究qmail的文档。
  
  软件包:
  
  qmail-1.03 qmail基本系统。在http://em.ca/~bruceg/qmail+patches/上有一个好的补丁包,里面有若干针对Qmail的POP3d及其他问题的补丁,笔者建议您把它下载过来。
  ucspi-tcp-0.88 tcpsever服务程序
  daemontools-0.70 监视工具
  checkpassword-0.81 pop3验证用户的程序
  ezmlm-0.53 邮件转发
  vpopmail-4.9.6-1 虚拟域用户pop3支持
  qmailadmin-0.35 虚拟域web管理
  autorespond-1.0.0 自动回复程序
  sqwebmail-1.2.0 webmail
  vqsignup-0.4 web方式用户注册
  
  
  软件来源:
  http://www.qmail.org
  http://www.inter7.com/qmail
  每个包安装前务必先仔细阅读INSTALL和FAQ,很多问题在FAQ都有解决方法。
  
  安装步骤:
  
  1. #mkdir /var/qmail
  
  2.设定组、用户权限
   # 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
  
  3.
   #tar xzvf qmail-1.03.tar.gz
  
   进入qmail目录后,仔细阅读一下README和INSTALL文件.然后开始编译qmail
  
   #make setup check
  
  4. #cd qmail-1.03
   #./config
  
  5.建立系统别名
   # (cd ~alias; touch .qmail-postmaster .qmail-mailer-daemon .qmail-root)
   # chmod 644 ~alias/.qmail*
  
  6.
   # cp /var/qmail/boot/home /var/qmail/rc
   # chmod 755 /var/qmail/rc
   编辑 /var/qmail/rc
   修改其中 ./Mailbox 成为 ./Maildir ,如下:
  
   # !/bin/sh
   # Using splogger to send the log through syslog.
   # Using qmail-local to deliver messages to ~/Maildir by default.
   exec env - PATH="/var/qmail/bin:$PATH"
   qmail-start ./Maildir splogger q
  
   其中 splogger qmail 指令是用来将纪录文件纪录于 / 中。
  
  建立样板
  
   $ /var/qmail/bin/maildirmake /etc/skel/Maildir
   $ echo ./Maildir/ > ~/.qmail
  
   注意 Maildir 必须为该使用者所有,可以 chown 变更,并以 chmod 700 Maildir 设定权限。
  
  7.安装 ucspi-tcp-0.88
   # tar zxvf ucspi-tcp-0.88.tar.gz
   # cd ucspi-tcp-0.88
   # make
   # make setup check
   执行档将被安装于 /usr/local/bin 中。
  
  8.安装 checkpassword
   # tar zxvf checkpassword-0.81.tar.gz
   # cd checkpassword-0.81
   # make
   # make setup check
   # chmod og-rx /bin/checkpassword
  
   执行档 checkpassword 将被安装于 /bin 中如果不对/etc/passwd中的用户开放mail,不需要装checkpassword,只要装vpopmail
  
  9.安装 daemontools
  
   # tar zxvf daemontools-0.70.tar.gz
   # cd daemontools-0.70
   # make
   # make setup check
   执行档将安装于 /usr/local/bin 中。安装本工具后可以用
  
   # mkdir /var/run/qmail
   # supervise /var/run/qmail /var/qmail/rc
  
   来启动qmail,可以用svc来关闭活重起qmail,用svstat监视qmail运行情况,(qmail FAQ)
  
  10.安装 vpopmail
  
   # groupadd vchkpw
   # useradd -g vchkpw vpopmail
   # mkdir ~vpopmail/etc
   # echo ":allow" > ~vpopmail/etc/tcp.smtp
   # tar zvfz vpopmail-4.9.6-1.tar.gz
   # cd vpopmail-4.9.6-1
   # ./configure --enable-roaming-users=y --enable-default-domain=mydomain.com --enable-passwd=n
   # make
   # make install-strip
  
   # crontab -e
   40 * * * * /home/vpopmail/bin/clearopensmtp 2>&1 > /dev/null
  
   # cd /home/vpopmail/bin
   # ./vadddomain mydomain.com mydomain
   append mydomain.com to /var/qmail/control/rcpthosts
  
  
  11.从Sendmail向Qmail迁移
  
    如果你的系统以前安装使用着Sendmail,就需要进行下面的步骤:
  
    11.1.首先找到Sendmail的启动程序,一般是在/etc/rc.d目录中,看上去像这样的命令:“sendmail -bd -q15m”,将其注释掉。
  
    11.2. 杀掉Sendmail进程。如果Sendmail有子进程,可以反复用-STOP和-CONT信号杀,直到没有子进程后用-TERM后加-CONT杀就可以了。
  
    11.3. 检查E-mail队列中是否还有信,如果认为有必要将它们发送出去,可以在以后一段时间不定期地运行“sendmail.bak -q”,直到队列清空。
  
    11.4. 去掉Sendmail等文件的setuid bit:
  
    # chmod 0 /usr/lib/sendmail
    # chmod 0 /usr/sbin/sendmail
    # chmod 0 /usr/lib/sendmail.mx
    # mv /usr/lib/sendmail /usr/lib
    /sendmail.bak
    # mv /usr/sbin/sendmail /usr
    /sbin/sendmail.bak
  
    11.5. 将csh -cf ′/var/qmail/rc &&′添加到启动文件中去。
  
    11.6. 安装Qmail的Sendmail外壳:
  
    # ln -s /var/qmail/bin/sendmail /usr/lib/sendmail
    # ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail
  
    11.7. 虚拟域与虚拟用户。
  
    将虚拟域名加入/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。VmailMgr是一个Qmail的增强工具,它扩展了Qmail的口令验证功能,使用户可以通过POP3 及IMAP访问自己的虚拟邮箱,我们将在以后的内容中重点介绍VmailMgr。
  
  12.激活qmail SMTP , POP3 daemon 系统服务
  
   建立 SMTP 转信规则
    建立 /etc/tcp.smtp 内容为
    :allow
   此为接受任何Client端所发出之转送信件
   若要拒绝某些IP所发出之Relay则改为 /etc/tcp.smtp如下
    1.2.3.4:allow,RELAYCLIENT=""
   127.:allow, RELAYCLIENT=""
   如此,除1.2.3.4及127.*之外的所有地址,都将被拒绝转送信件。
     
   接下来,转换 tcp.smtp 成为 cdb 格式。
   # /usr/local/bin/tcprules /etc/tcp.smtp.cdb /etc/tcp.smtp.tmp < /etc/tcp.smtp
  
   注意:若对 tcp.smtp 有任何变更,都必须经过 tcprules 转换成为 cdb 才会生效。另外,tcp.smtp 若为空白,则表示拒绝所有的转送,因为预设的规则为 deny。至此,转送规则已建立,稍后将依此规则激活 qmail-smtpd。
  
    设定 SMTP 及 POP3 daemon 之激活
    请移除 inetd.conf 中有关 smtp 及 pop3 的设定 (加上 # 号)
    编辑 /etc/services,改为以下设定:
  
    smtp 25/tcp mail
   # pop-3 110/tcp #pop version 3
    # pop-3 110/udp
   pop3 110/tcp
    pop3 110/udp
  
    激活 SMTP:
    /usr/local/bin/tcpserver -v -x /etc/tcp.smtp.cdb
    -u UID -g GID 0 smtp /var/qmail/bin/qmail-smtpd 2>&1
    | /var/qmail/bin/splogger smtpd 3 &
  
    其中UID和GID为前述新增 qmail 系统帐号之 qmaild 之 User ID,以及 nofiles 之 group ID。
    /var/qmail/bin/splogger那一行会将log档写在 /var/log/maillog。
  
   激活 POP3:
    编辑激活档加入以下设定:
   tcpserver -H -R 0 pop3
   /var/qma 本文作者:
« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3