安装qmail(首先确保DNS是配置好的)
软件准备:
qmail-1.03.tar.gz
ucspi-tcp-0.88.tar
daemontools-0.76.tar.gz
qmail-103.patch
checkpassword-0.90.tar
1>安装qmail:
[root@email /usr/local/src]# gzip -d qmail-1.03.tar.gz
[root@email /usr/local/src]# tar xf qmail-1.03.tar
[root@email /usr/local/src]# cd qmail-1.03
对qmail打补丁(需将.patch文件拷到qmail目录下)
[root@email /usr/local/src/qmail-1.03]# patch –p1 < qmail-103.patch(是p壹)
创建qmail主目录及添加必须的系统用户
由于qmail不是以root身份运行,而且qmail是同时由多个程序处理不同的工作,如接收邮件,发送邮件,本地投递等等, 所以需要多个用户身份:
# mkdir /var/qmail
[root@email /]# /usr/sbin/groupadd nofiles
[root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail/alias -s /bin/false alias
[root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmaild
[root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmaill
[root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmailp
[root@email /]# /usr/sbin/groupadd qmail
[root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmailq
[root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmailr
[root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmails
编译
[root@email /usr/local/src/qmail-1.03]# make setup check
这个命令将会完成所有的编译工作,生成所有的二进制程序,并将其拷贝到相应的目录,缺省qmail是安装在/var/qmail目 录下。
2>安装daemontools-0.76.tar.gz
[root@mail src]# tar xvfz daemontools-0.76.tar.gz
[root@mail src]# cd admin
[root@mail src]# cd daemontools-0.76
[root@maildaemontools-0.76]# package/install
即可实现daemontools的安装。
3> qmail配置
qmail编译成功以后就应该开始对其进行配置,最简单的实现配置的方法是使用命令config:
[root@mail qmail-1.03]# ./config
config程序将试图对本地地址进行反向解析,以确定本机域名;若反向解析失败,则配置也就失败。可以参考 INSTALL.ctl文件内容。也可以在运行config程序时指定本机域名信息:
用以下命令来增加域名
[root@mail qmail-1.03]# ./config-fast your.full.host.name
若你的主机有若干个域名,并且多个域的MX记录也指向该主机,则你就需要编辑/var/qmail/control/目录下的文件locals和 rcpthosts,在其中加入多个域名,例如本机器具有域名email.secfocus.com和email.secfocus.net,并且这两个域的MX记录分别指向email.secfocus.com和email.secfocus.net。则locals中应该具有如下内容:
localhost
email.secfocus.com
secfocus.com
email.secfocus.net
secffocus.net
而文件rcpthosts具有以下内容:
localhost
email.secfocus.com
secfocus.com
email.secfocus.net
secfocus.net
下一步 需要对某些不能接收邮件的系统帐户添加别名:
[root@mail /usr/local/src/qmail-1.03]# cd /var/qmail/alias
[root@mail /var/qmail/alias]# echo adam > .qmail-root
[root@mail /var/qmail/alias]# echo bob > .qmail-postmaster
[root@mail /var/qmail/alias]# echo bob > .qmail-mailer-daemon
这里的bob或adam是系统管理员的普通用户帐号。qmail在接收到一个发给用户user1的信件,qmail-local则首先寻找名为user1的用户,若没有找到,qmail-local将去查询是否有名字为user1的别名用户,若有则发信给user1对应的真正用户。其中别名是通过在/var/qmail/alias中定义的,[root@mail ideal]$echo ./Maildir/ >/home/ideal/.qmail
4>.设置daemontools
(这一步的所有要建的文件夹及文件都在web-file/qmail下的supervise)
下面设置当系统启动时自动启动qmail。这里要使用daemontool里面的svcan工具,这些第三方的工具的使用和含义参见附录A。按照前面的步骤,现在daemontools应该已经安装在/usr/local/bin目录下。
首先,需要创建daemontools服务工作目录,该工具的作者推荐/service,这里我们就使用缺省目录:
[root@email /]# mkdir /service
[root@email /]# mkdir /var/qmail/supervise
[root@email /]# mkdir /var/qmail/supervise/qmail-send
[root@email /]# chmod +t /var/qmail/supervise/qmail-send
[root@email /]# mkdir /var/qmail/supervise/qmail-send/log
[root@email /]# mkdir /var/qmail/supervise/qmail-smtpd
[root@email /]# chmod +t /var/qmail/supervise/qmail-smtpd
[root@email /]# mkdir /var/qmail/supervise/qmail-smtpd/log
[root@email /]# mkdir /var/log/qmail
[root@email /]# mkdir /var/log/qmail/qmail-send
[root@email /]# mkdir /var/log/qmail/qmail-smtpd
[root@email /]# chown qmaill /var/log/qmail
[root@email /]# chown qmaill /var/log/qmail/*
下来,需要创建/var/qmail/supervise目录下的内容:
[root@mail rc5.d]# cd /var/qmail/supervise/qmail-send
在该目录下创建名为run的script内容如下:
#!/bin/bash
exec /var/qmail/rc
在目录/var/qmail/supervise/qmail-send/log下创建run文件,内容如下:
#!/bin/bash
exec /usr/local/bin/setuidgid qmaill /usr/local/bin/multilog t
s2500000 /var/log/qmail/qmail-send
在目录/var/qmail/supervise/qmail-mtpd下创建run文件,内容如下:
#!/bin/sh
QMAILDUID=`id -u qmaild`
NOFILESGID=`id -g qmaild`
exec /usr/local/bin/softlimit -m 2000000
/usr/local/bin/tcpserver -v -p -x /etc/tcp.smtp.cdb
-u $QMAILDUID -g $NOFILESGID 0 smtp /var/qmail/bin/qmail-smtpd
2>&1
在目录/var/qmail/supervise/qmail-smtpd/log/下创建run文件,内容如下:
#!/bin/bash
/usr/local/bin/setuidgid qmaill /usr/local/bin/multilog t
s2500000 /var/log/qmtpd
将这几个script的属性均修改为可执行:
[root@mail /]# chmod +x run
由于svscan的工作方式,我们这里不在/service内创建真正的目录,而是创建符号连接/var/qmail/supervise下的真正目录。
5>启动qmail
拷贝/var/qmail/boo/home 到/var/qmail/rc
chmod +x rc
之后就需要在/service下创建到/var/qmail/supervise下各个目录的的符号链接
[root@mail qmail]# ln -s /var/qmail/supervise/* /service/
6>安装ucspi-tcp和mysql
ucspi-tcp-0.88.tar.gz
MySQL-3.22.32-1.i386.rpm
MySQL-client-3.22.32-1.i386.rpm
MySQL-share-3.22.32-1.i386.rpm
MySQL-devel-3.22.32-1.i386.rpm
安装ucspi-tcp
make
make setup check
安装mysql
rpm –ivh 各个软件包
后启动mysql
mysql –u root mysql
>update user set password=password(‘你希望得密码’) where user=’root’;
后重启机器。
7>安装vpopmail
vpopmail-4.9.8-1.tar.gz 或 vpopmail-5.2.tar.gz
(sqwebmail-3.x以上要安装vpopmail-5.2.tar.gz,安装过程是一样得。)
首先安装好ucspi-tcp
编辑/etc下得tcp.smtp文件如下:
127.0.0.1:allow,RELCYCLIENT=””
192.168.0.:allow,RELCYCLIENT=””
:allow
第一步:修改文件/usr/src/vpopmail-4.9.4/vmysql.h,修改
/* Edit to match your set up */
#define MYSQL_SERVER "localhost"
#define MYSQL_USER "root"
#define MYSQL_PASSWD "passwoerd"
/* End of setup section*/
中mysql服务器的地址,若你的mysql服务器存放在其他机器上,则将localhost修改为你的mysql服务器的ip地址;若你希望使用其他具有对数据库读写及创建库和表格的用户来访问数据库,则将root为你希望的用户名;将passwoerd修改为你的mysql数据库对应的访问密码。
拷贝//usr/local/lib/mysql下的所有内容到/lib/中
第二步:创建需要的用户和组:
/usr/sbin/groupadd vchkpw
/usr/sbin/useradd -g vchkpw vpopmail
第三步:配置编辑vpopmail:
./configure --enable-roaming-users=y --enable-hardquota=10000000 (这里如是高版本的是delfaulquota
--enable-default-domain=secfocus.com --enable-mysql=y
--enable-sqlincdir=/usr/local/include/mysql/
--enable-sqllibdir=/usr/local/lib/mysql
--enable-ucspi-dir=../ucspi-tcp-0.88 --enable-passwd=n
(注:以上全为一行)
make
make install
第四步:添加虚拟域
/home/vpopmail/bin/vadddomain domain1.com
/home/vpopmail/bin/vaddaliasdomain domain2.com
8>设置pop3及smtp
首先安装checkpassword 和ucspi-tcp
在/etc/xinetd.d 目录下建立pop-3和smtp如下。
cat > smtp
service smtp
{
socket_type =stream
protocol =tcp
wait =no
user =qmaild
server =/var/qmail/bin/qmail-smtpd
server_args = 2>&1 | /var/qmail/bin/splogger smtpd 3& /
disable =no
}
#cat > pop-3
service pop-3
{
socket_type =stream
protocol =tcp
wait =no
user =root
server =/var/qmail/bin/qmail-popup
server_args = abc.com home/vpopmail/bin/vchkpw /var/qmail/bin/qmail-pop3d Maildir &
这时候从客户端使用outlook express等MUA软件,应该可以收到刚才测试所发送的邮 件。(有时你的pop-3会出现在本机上起来了,而在远程起不来,就请停掉iptables/ipchains. 
9>删除sendmail
#> killall –9 sendmail
#> mv /usr/lib/sendmail /usr/lib/sendmail.old
#> mv /usr/sbin/sendmail /usr/sbin/sendmail.old
#> ln –s /var/qmail/bin/sendmail /usr/lib/sendmail
#> ln –s /var/qmail/bin/sendmail /usr/sbin/sendmail
10>安装sqwebmail
sqwebmail-3.3.7.tar.gz
如你安装的是sqwebmail-5.2的版本在/home/vpopmail/etc/目录下不会有inc_deps lib_deps这两个文件。则需建立这两个文件。内容如下:
inc_deps的内容如下:
-I/home/vpopmail/include
~
lib_deps的内容如下:
-L/home/vpopmail/lib -lvpopmail
(如不建的话./configure 时会出错哟)
设置环境变量(加在root得.bash_profile下)
INCS=-I/usr/include/mysql
export INCS
LIBS="-L/usr/lib/mysql -lmysqlclient -lz"
export LIBS
CPPFLAGS=-I/usr/include/mysql
LDFLAGS=-L/usr/lib/mysql
export CPPFLAGS
export LDFLAGS
安装:
./configure --with-cachedir --without-gzip --enable-webpass=yes
--enable-softtimeout=300 --enable-autopurge=180 --enable-maxpurge=180
--with-htmllibdir=/var/www/sqwebmail --enable-cgibindir=/var/www/cgi-bin
--enable-imagedir=/var/www/images/sqwebmail
--enableimageurl=/images/sqwebmail/
--enable-mimecharset=gb2312 --with-maxargsize=5000000
--with-maxformargsize=5000000 --with-maxmsgsize=5000000 --without-ispell
--with-authshadow --with-authmysql --with-authldap --with-authuserdb
--with-authpwd --without-authpam --with-authvchkpw --without-authdaemon
(以上全为一行,建议不要设置所有得images路径)
make
configure-check
make
make check
make install-strip
make install-configure
打开浏览器,http://xxx.xxx.xxx.xxx/cgi-bin/sqwebmail
输入用户名、口令,OK!(系统用户直接输入用户名、虚拟域用户输入Email地址:user@domain.com)
11>安装vqsignup(自动注册软件)
(注意:以下所有得权限设置都在移动完成后在目标文件夹中做)
1.首先下载vqsignup-0.4.tar.gz软件包,解开。
2.进入源代码目录,编辑Makefile文件。
指定vpopmail所带的头文件include目录。如:
FLAGS=-I/home/vpopmail/include
同时指定vpopmail的库文件目录,以及libypopmail.a 和 libcrypt.a这两个库文件。
如:
$(CC) $(FLAGS) -o $(BIN) $(OBJS) -L/home/vpopmail/lib -lvpopmail -lcrypt
正保存所作改动后,编译源代码。
make
3.将生成的vqsignup.cgi拷贝到cgi-bin目录下,并且改变其的权限:
cp vqsignup.cgi /home/httpd/cgi-bin
chown vpopmail vqsignup.cgi
chgrp vchkpw vqsignup.cgi
设置vqsignup 的 setuid 位,
chmod ug+s vqsignup.cgi
4.将vqsignup.conf拷贝到cgi-bin目录下,并且
chmod ugo+r vqsignup.conf
5.将vqsignup_html目录拷贝到cgi-bin目录下,并且
chmod ugo+r vqsignup_html
6. 将vqsignup.html拷贝到/home/httpd/html目录下,并且
chmod ugo+r vqsignup.html
7.在cgi-bin目录下编辑vqsignup.conf文件,在”add_domain”一行中更新为所指定
的虚拟域,如:
add_domain ssw.com
add_domain unix.xom
在"result_*"写上所有html文件的绝对路径,如:
result_error /home/httpd/cgi-bin/vqsignup_html/error.html
result_failed_user /home/httpd/cgi-bin/vqsignup_html/failed-user.html
result_failed_pass /home/httpd/cgi-bin/vqsignup_html/failed-pass.html
result_failed_domain /home/httpd/cgi-bin/vqsignup_html/failed-domain.
result_fields /home/httpd/cgi-bin/vqsignup_html/fields.html
result_domain /home/httpd/cgi-bin/vqsignup_html/domain.html
result_success /home/httpd/cgi-bin/vqsignup_html/success.html
8.在vqsignup_html目录中编辑每一个html文件,更新为邮件服务所支持的一些虚
拟域名
9.在/home/httpd/html目录在编辑vqsignup.html文件,更新为邮件服务器所支持的一
些虚拟域名。g
10.进行测试
在IE浏览器中键入http://你的服务器/vqsignup.html就可以用户自己提交并完成邮
箱的建立。
汉化我是对html页面进行汉化,中文乱码我是用我说的vbscrip来处理的。其它的我没有考虑,所以我做的不是很好,请大虾们给我点建议。
还有,
www.hleil.com是一个不错的qmail技术论坛,上面有几个牛人!
zlzj2010 回复于:2003-08-12 11:44:21 |
忘了一点,测试你的邮件服务器的例子,假设我的地址时10.0.0.222,域名时:abc.net 用户时,hello,密码时hello,hello的base64编码是:aGVsbG8=
smtp测试: $ telnet 10.0.0.222 25 Trying 10.0.0.222... Connected to 10.0.0.222 (10.0.0.222). Escape character is '^]'. 220 abc.net ESMTP ehlo 250-abc.net 250-AUTH LOGIN CRAM-MD5 PLAIN 250-AUTH=LOGIN CRAM-MD5 PLAIN 250-PIPELINING 250 8BITMIME auth login 334 VXNlcm5hbWU6 aGVsbG8= 334 UGFzc3dvcmQ6 aGVsbG8= 235 ok, go ahead (#2.0.0) mail from hello@abc.net 250 ok rcpt to:hello@abc.net 250 ok data 354 go ahead asdf asdf asdf . 250 ok 1060659046 qp 22272 quit 221 abc.net Connection closed by foreign host. pop3测试: $ telnet 10.0.0.222 110 Trying 10.0.0.222... Connected to 10.0.0.222 (10.0.0.222). Escape character is '^]'. +OK <22309.1060659271@abc.net> user hello +OK pass hello +OK list +OK 1 231 . retr 1 +OK Return-Path: <> Delivered-To: hello@abc.net Received: (qmail 22272 invoked from network); 12 Aug 2003 03:30:42 -0000 Received: from unknown (HELO  (hello@10.0.0.222) by 0 with SMTP; 12 Aug 2003 03:30:42 -0000 asdf asdf asdf . dele 1 +OK quit +OK Connection closed by foreign host. 看,刚才发送的邮件收到了,试试把,祝你好运. |
zlzj2010 回复于:2003-08-12 11:46:03 |
smtp认证采用的是base64的编码,测试时用户名和密码都应该为base64编码后的
关于base64编码的程序网上比较多,大家可以取搜索一下! |
zlg88 回复于:2003-08-17 20:35:09 |
在测试25端口时,进入验证的命令:
auth login 334 VXNlcm5hbWU6 aGVsbG8= 334 UGFzc3dvcmQ6 aGVsbG8= 其中的"aGVsbG8= "是什么意思,我这里总是报 535 authorization failed (#5.7.0) 能否帮忙解决一下? |
gadfly 回复于:2003-08-17 20:43:02 |
分别是base64过的用户名和密码,最好用客户端软件测试 |
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/
领测软件测试网最新更新
关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073