使用qmailadmin实现qmail邮件账户的web管理之一
摘要:本文在“通过vpopmail实现qmail邮件账户的数据库管理”一文的基础上讨论如何通过qmailadmin实现对存放在数据库中的虚拟域邮件用户账号进行web管理。通过qmailadmin管理员可以通过web方式实现添加删除用户及修改用户密码等邮件用户的管理,而用户可以自行修改自己的密码。硬件环境:HP Netserver E60 128M内存 单网卡
软件环境:redhat6.2 vpopmail4.9.4 qmail1.3 Mysql-3.23.22-beta ucspi-tcp-0.88 qmailadmin-0.38.tar.gz autorespond-1.0.0.tar.gz ezmlm-idx
前言
1、mysql安装
2、vpopmail安装过程
3、vpopmail的详细配置选项
4、Qmail和虚拟域
5、笔者安装过程
前言
在阅读了“通过vpopmail实现qmail邮件账户的数据库管理”一文以后,大家下一个关心的问题就是如何采用web方式实现对邮件用户的管理,而避免了每次添加用户都需要登录到邮件服务器的麻烦。Inter7开发了遵从GPL版权的qmailadmin来实现这个功能。
要使用该软件,邮件服务器的上必需运行有apache的www服务器。
1、下载必需的软件包
qmailadmin提供的功能必须在实现了虚拟域及虚拟用户的账号的web方式以后,才能进行,如果你在服务器上还没有实现“通过vpopmail实现qmail邮件账户的数据库管理”,则请阅读该文章,并完成了虚拟域及用户的配置以后才能开始本文的工作。要实现qmailadmin的功能,需要下载下面新的软件包:
qmailadmin0.38.tar.gz http://www.inter7.com/qmailadmin/
autorespond-1.0.0.tar.gz http://www.vpopmail.cx/autorespond-1.0.0.tar.gz
autorespond用来支持实现邮件的自动回复,例如您的电子邮件地址为ideal@zzzyk.com,由于您最近出差,不能及时回复收到的邮件,则你可以使用该软件包实现邮件的回复,当结合使用qmailadmin时,原理如下:
当使用web管理界面指定对某个用户(如ideal)指定邮件自动回复,则在该用户所在的域内,创建一个文件名字为.qmail-ideal.
下面我们首先讨论qmail的邮件投递机制:
qmail的投递机制为:当接受到一个信件后,由qmail-lspawn控制邮件投递机制;它首先察看qmail-users机制(qmail-users是一个给用户指派-assign-地址的系统),若收信人地址没有定义在assign文件中(/var/qmail/assign参阅Life with qmail 的3.6qmail-users)则激活qmail-getpw程序,然后调用qmail-local来实现本地邮件投递。qmail-local首先试着投递邮件到localpart@host的地址,其中localpart为本地用户名。若没有找到,则进一步察看/var/qmail/alias中定义的别名,若存在对应的别名则投递邮件到别名对应的用户目录下,否则退回邮件。
若按照qmail-users机制在assign中找到对应于邮件目的地址的规则,则从users/assign得到相关信息,然后进行标准的.qmail文件操作。一般来说,.qmail-
从上面的机制中可以看到,通过qmailadmin为ideal用户创建邮件自动回复时会在用户所在的域目录中(如:/home/vpopmail/domains/domains.com.cn中创建.qmail-ideal文件,当.qmail-local进入assign处理以后将会首先进行标准的.qmail文件操作,所以将会根据该文件进行邮件自动回复。现在我们看看.qmail-ideal的文件内容:
|/usr/local/bin/autorespond 10000 5 /home/vpopmail/domains/domain.com.cn/AU
TORESPONGDING/message /home/vpopmail/domains/domain.com.cn/AUTORESPONGDING
&ideal@btamail.net.cn
其中|表示调用一个程序来处理该邮件这里是调用autorespond来处理;10000表示允许处理信件的总时间;5表示在这段时间内的最大邮件数;/home/vpopmail/domains/domain.com.cn/AU
TORESPONGDING/message指示自动回复的邮件内容的消息文件;/home/vpopmail/domains/domain.com.cn/AUTORESPONGDING指定log文件位置。其中&ideal@btamail.nte.cn表示同时将邮件转发给&ideal@btamail.net.cn,也可以在添加自动回复时不指定转发。
ezmlm-0.53.tar.gz http://www.ezmlm.org/
ezmlm-0.53是一个由Dan J. Bernstein编写的基于qmail的邮件列表管理软件,它具有邮件列表管理器所应该具有的所有基本功能,例如订阅者地址列表管理、自动消息退回处理和消息发布和归档等等。
2、qmailadmin的安装配置选项
在编译该软件包以前,需要根据自己的需要对软件包进行编译配置,下面我们就讨论所有的配置选项含义如下(配置选项的使用方法为:./configure conf_option=chosen):
若您的服务器的cgi-bin不在标准的位置,则使用该配置选项指定正确的cgi-bin目录的位置:
--enable-cgibindir={dir} WWW服务器的cgi-bin目录路径
若您不希望邮件管理界面的HTML模版存放在/usr/local/share/qmailadmin,则使用该选项:
--with-htmllibdir={dir} qmailadmin HTML 模版存放目录路径
若您的qmail路径不是缺省的/var/qmail,则使用该选项指定正确的qmail安装路径:
--enable-qmaildir={dir} qmail的安装路径
若访问WWW服务器时的cgi-bin路径不是/cgi-bin/cgi_program则需要指定该配置选项:
--enable-cgipath={/cgi-bin/qmailadmin}
若vpop用户不是缺省的vchkpw用户,则使用该选项指定正确的用户名:
--enable-vpopuser={vpopuser}
若autorespond安装路径不是缺省的/user/local/bin,则使用该选项指定路径:
--enable-autoresponder-bin={path}
若ezmlm 安装路径不是缺省的 /user/local/bin/ezmlm,则使用该选项指定路径:
--enable-ezmlmdir={dir}
若希望限定系统的最大pop用户数量则使用该选项指定:
--enable-maxpopusers=unlimited -1为没有限制,0则是关闭该功能
使用该选项指定系统的最大别名(alias)数:
--enable-maxaliases=unlimited -1为没有限制,0则是关闭该功能
使用该选项指定系统的最大邮件转发(forward)数:
--enable-maxforwards=unlimited -1为没有限制,0则是关闭该功能
使用该选项指定系统的最大邮件自动回复(autoresponder)数:
--enable-maxautorepsonders=unlimited -1为没有限制,0则是关闭该功能
使用该选项来设定系统最大的邮件列表数量:
--enable-maxmailinglists=unlimited 缺省为没有限制。
3、qmailadmin及相关软件包的编译
autorespond的编译生成:
[root@mail src]# tar xvfz autorespond-1.0.0.tar.gz
[root@mail src]# [root@www src]# cd autorespond-1.0.0
[root@mail autorespond-1.0.0]# gcc -Wall -o autorespond autorespond.c
[root@mail autorespond-1.0.0]# cp autorespond /usr/local/bin/
ezmlm的编译生成:
[root@mail src]# tar xvfz ezmlm-0.53.tar.gz
[root@mail src]# cd ezmlm-0.53
[root@mail ezmlm-0.53]# make
[root@mail ezmlm-0.53]# make man
[root@mail ezmlm-0.53]# make seup
qmailadmin的编译生成(这里是按照前两篇文章的缺省安装进行配置的):
1
[root@www qmailadmin-0.38]# ./configure --enable-cgibindir=/usr/local/apache/cgi
-bin/ --enable-cgipath=/cgi-bin/qmailadmin
2
[root@www qmailadmin-0.38]# make clean
3
[root@www qmailadmin-0.38]# make
在进行make这一步时,可能会出现如下的错误,
gcc -g -O2 -o qmailadmin qmailadmin.o alias.o autorespond.o forward.o mailing
list.o sysadmin.o user.o util.o auth.o template.o command.o show.o cgi.o limits.
o dotqmail.o -L/home/vpopmail/lib -lvpopmail -lnsl -lm -lcrypt
/home/vpopmail/lib/libvpopmail.a(vauth.o): In function `vauth_open':
/usr/src/vpopmail-4.9.4/vauth.c:59: undefined reference to `mysql_init'
/usr/src/vpopmail-4.9.4/vauth.c:61: undefined reference to `mysql_real_connect'
... ...
你需要使用vi修改/usr/src/qmailadmin-0.38/Makefile文件,将:
COMMONLDADD = -L/home