当前位置:Linux教程 - Email - email - 基于AS3平台的Qmail企业级邮件服务器配置指南

email - 基于AS3平台的Qmail企业级邮件服务器配置指南

基于AS3平台的Qmail企业级邮件服务器配置指南
2004-04-23 15:18 pm
来自:Linux文档
现载:Www.8s8s.coM
地址:无名

AS3+Qmail+smtp-auth+vpopmail+Mysql+Igenus+ezmlm+autorespond+qmailadmin+sqwebmail

声明:转帖时必须加注来源于http://www.linuxsir.org PinkSnoopy,以及保留此声明;
本帖操作环境是Redhat AS3,文章中提到的软件在LinuxSir首页有打包,方便大家下载!

AS3+Qmail+smtp-auth+vpopmail+Mysql+Igenus+ezmlm+autorespond+qmailadmin+sqwebmail

声明:转帖时必须加注来源于http://www.linuxsir.org PinkSnoopy,以及保留此声明;
本帖操作环境是Redhat AS3,文章中提到的软件在LinuxSir首页有打包,方便大家下载!

AS3默认安装后,mysql缺少mysql-server-3.23.58-4.i386.rpm,装上去!然后测试是否可以正常使用

root: ~ $ cp /web/mysql/lib/mysql/* /usr/lib/
root: ~ $ cp /web/mysql/include/mysql/* /usr/include/

###################
首先进行安装ucspi-tcp-0.88
AS3的glibc的版本问题,打完补丁才能正常编译

root: ~ $ tar zxvf ucspi-tcp-0.88.tar.gz
root: ~ $ cd ucspi-tcp-0.88
root: ~ $ patch -p1 < ucspi-tcp-0.88.a_record.patch 补丁所在路径
root: ~ $ patch -p1 < ucspi-tcp-0.88.errno.patch 补丁所在路径
root: ~ $ patch -p1 < ucspi-tcp-0.88.nobase.patch 补丁所在路径
root: ~ $ make
root: ~ $ make setup check

##################

安装qmail-1.03

root: ~ $ mkdir /var/qmail
root: ~ $ mkdir /var/qmail/alias

建立组及用户

root: ~ $ groupadd nofiles
root: ~ $ groupadd qmail
root: ~ $ useradd alias -g nofiles -d /var/qmail/alias -s /nonexistent
root: ~ $ qmaild -g nofiles -d /var/qmail -s /nonexistent
root: ~ $ useradd qmaill -g nofiles -d /var/qmail -s /nonexistent
root: ~ $ useradd qmailp -g nofiles -d /var/qmail -s /nonexistent
root: ~ $ useradd qmailq -g qmail -d /var/qmail -s /nonexistent
root: ~ $ useradd qmailr -g qmail -d /var/qmail -s /nonexistent
root: ~ $ useradd qmails -g qmail -d /var/qmail -s /nonexistent

打补丁及编绎安装qmail

root: ~ $ tar zxvf qmail-1.03.tar.gz
root: ~ $ tar zxvf qmail-smtpd-auth-0.31.tar.gz
root: ~ $ cp qmail-smtpd-auth-0.31/base64.* qmail-1.03 打smtp-auth补丁,支持smtp认证
root: ~ $ patch -d qmail-1.03 < qmail-smtpd-auth-0.31/auth.patch 补丁路径
root: ~ $ cd qmail-1.03
root: ~ $ patch -p1 < qmail-103.patch 补丁路径
root: ~ $ patch -p1 < qmailqueue-patch 补丁路径
root: ~ $ patch -p1 < qmail-maildir++.patch 补丁路径
root: ~ $ patch -p1 < qmail-1.03.errno.patch 补丁路径
root: ~ $ patch -p1 < qmail-1.03.qmail_local.patch 补丁路径
root: ~ $ vi qmail-smtpd.c 搜索函数straynewline中的451改为553

// 当你的服务器收到无效格式的邮件时,会发送:"I am not going to accept that message at the moment,you can try again later",对方服务器收到后,几秒钟后又会发送同样的邮件给你,造成多次的重复。
// 改为553后,你的服务器将直接发送:"I am not going to accept that message,don't try sending it again.",告诉对方的服务器不要再发这封无效的信件。

root: ~ $ make setup check
root: ~ $ ./config-fast mailsnoopy.gov 这里改为你的域名

添加别名用户

root: ~ $ touch /var/qmail/alias/.qmail-root
root: ~ $ touch /var/qmail/alias/.qmail-postmaster
root: ~ $ touch /var/qmail/alias/.qmail-mailer-daemon
root: ~ $ chmod 644 /var/qmail/alias/.qmail*
root: ~ $ echo postmaster > /var/qmail/control/bouncefrom 退回邮件
root: ~ $ echo mail.snoopy.gov > /var/qmail/control/helohost 主机名(解决新浪拒收邮件问题)
root: ~ $ echo 10485760 > /var/qmail/control/databytes 接收邮件的最大容量 (0=无限制)??
root: ~ $ echo 40 > /var/qmail/control/concurrencylocal 本地同时投递邮件的数目
root: ~ $ echo 40 > /var/qmail/control/concurrencyremote 同时投递至远程主机的数目

/var/qmail/control/locals 确保文件中有缺省域名,否则投递失败的邮件将不知所踪

如果存在postfix和sendmail,或其他邮件服务,停用现在的mail服务,或则删除它!

root: ~ $ /etc/rc.d/init.d/sendmail stop
root: ~ $ cp /var/qmail/bin/sendmail /usr/sbin/qmail.sendmail
root: ~ $ rm -f /etc/alternatives/mta
root: ~ $ ln -s /usr/sbin/qmail.sendmail /etc/alternatives/mta

root: ~ $ ln -s /var/qmail/bin/sendmail /usr/lib/sendmail
root: ~ $ ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail
root: ~ $ chmod 777 /usr/sbin/sendmail 这里特别要注意检查/usr/sbin/sendmail的属性.不然会导致装完后用igenus在web界面发信不成功

###################

安装vpopmail

root: ~ $ mkdir /home/vpopmail
root: ~ $ mkdir /home/vpopmail/etc

添加用户和组

root: ~ $ groupadd vchkpw
root: ~ $ useradd -g vchkpw vpopmail

添加mysql的vpopmail用户,用于操作vpopmail数据库

root: ~ $ mysql -p

mysql>create database vpopmail; 进入mysql命令行

mysql>grant all on vpopmail.* to vpopmail@localhost identified by "密码";

编译安装vpopmail

root: ~ $ tar zxvf vpopmail-5.2.1.tar.gz
root: ~ $ cd vpopmail-5.2.1
root: ~ $ vi vmysql.h

#define MYSQL_UPDATE_SERVER "localhost" mysql服务器名
#define MYSQL_UPDATE_USER "vpopmail" 用户名
#define MYSQL_UPDATE_PASSWD "snoopyx" 改成你设置的密码

#define MYSQL_READ_SERVER "localhost" mysql服务器名
#define MYSQL_READ_USER "vpopmail" 用户名
#define MYSQL_READ_PASSWD "snoopyx" 改成你设置的密码

创建tcp.smtp文件(或者使用/etc/tcp.smtp)

root: ~ $ vi /home/vpopmail/etc/tcp.smtp

127.0.0.1:allow,RELAYCLIENT=""
:allow

root: ~ $ cd /home/vpopmail/etc
root: ~ $ tcprules tcp.smtp.cdb tcp.smtp.tmp < tcp.smtp

进行编译

root: ~ $ ./configure --prefix=/home/vpopmail 指定安装路径
--enable-mysql=y 是否应用Mysql数据库
--enable-incdir=/usr/include/mysql Mysql数据库include文件所在目录
--enable-libdir=/usr/lib/mysql Mysql数据库lib文件所在目录
--enable-default-domain=snoopy.gov 定义虚拟域名
--enable-passwd=n 是否使用系统密码验证方式
--enable-defaultquota=10485760 定义缺省邮箱大小,10485760为10MB,20971520为20MB,52428800为50MB
--enable-tcprules-prog=/usr/local/bin/tcprules 指定tcprules目录
--enable-tcpserver-file=/home/vpopmail/etc/tcp.smtp 指定tcprules应用规则文件
--enable-vpopuser=vpopmail vpopmail的用户
--enable-vpopgroup=vchkpw vpopmail的组
--enable-ip-alias-domains=n 在虚拟域中允许通过反向IP地址查找虚拟域名
--enable-sqwebmail-pass=y sqwebmail密码验证支持
--enable-hardquota=10000000 限制磁盘限额为10M就需要使用下面这个配置参数,若磁盘限额超出,将拒绝接受该用户的新邮件,并返回一封拒绝信息邮件,其中的信息可以定制
root: ~ $ make
root: ~ $ make install-strip

创建虚拟域

root: ~ $ cd /home/vpopmail/bin
root: ~ $ ./vadddomain 域名 (密码)
在mysql数据库vpopmail中自动生成vpopmail表单,生成的密码是postmaster@?蛎驶У拿苈耄院蟮锹絨mailadmin就是使用postmaster登陆的

root: ~ $ ./vadduser 用户名 密码
会自动往表vpopmail中添加用户数据,用户添加到默认的域里面。如果要添加到其他的虚拟域,用户名要带域名,如[email protected])
如果不成功的话,则必须先删除创建的域,./vdeldomain 域名 不要使用手工操作mysql删除域和用户帐号(除非你特别熟悉),否则会引起系统帐户的紊乱

########################

smtp-auth的设置

root: ~ $ chmod 4755 vchkpw
root: ~ $ chown root.root vchkpw

如果使用带验证的smtp,smtp进程要调用密码验证程序,则必须要使用 setuid 和setgid。提高vchkpw的权限,才能完成setgid操作。

接下来安装cmd5checkpw

root: ~ $ tar zxvf cmd5checkpw-0.22.tar.gz
root: ~ $ cd cmd5checkpw-0.22
root: ~ $ make
root: ~ $ mkdir /usr/man
root: ~ $ mkdir /usr/man/man8
root: ~ $ make install

注意,因为使用vpopmail,所以checkpassword可以不用安装!

生成qmail的启动脚本

root: ~ $ cp /var/qmail/boot/home /var/qmail/rc
root: ~ $ vi /var/qmail/rc 对rc文件进行修改,以决定投送方式

#!/bin/sh

# Using splogger to send the log through syslog.
# Using dot-forward to support sendmail-style ~/.forward files.
# Using qmail-local to deliver messages to ~/Mailbox by default.

exec env - PATH="/var/qmail/bin:$PATH" qmail-start ./Maildir/ splogger qmail &


root: ~ $ vi /var/qmail/pop3 编辑pop3服务的启动脚本

#!/bin/sh

/usr/local/bin/tcpserver -l mail.snoopy.gov -U -c 100 -H -R 0 pop3 /var/qmail/bin/qmail-popup mail.snoopy.gov /home/vpopmail/bin/vchkpw /var/qmail/bin/qmail-pop3d Maildir &

root: ~ $ chmod 755 /var/qmail/rc
root: ~ $ chmod 755 /var/qmail/smtp
root: ~ $ chmod 755 /var/qmail/pop3

运行qmail并测试

root: ~ $ /var/qmail/rc
root: ~ $ /var/qmail/smtp
root: ~ $ /var/qmail/pop3
root: ~ $ ps aux | grep "qmail" 查看qmail的服务进程是否已完全正常启动

如果qmail已正常启动,用outlook测试qmail的smtp和pop3是否正常,注意由于vpopmail支持虚拟域名,在outlook中设置邮件帐号时,用户名后要加上域名,像[email protected]。smtp是带认证的,在outlook中也要作相应设置。建议先将qmail测试正常后再安装igenus。如果qmail出现问题,可查看mysql中的vpopmail数据库,/var/log下的mysqld和maillog日志记录

注意: 如果你在X下用X的kmail客户端测试,smtp的验证要选择LOGIN,POP的验证选择纯文本(APOP是错的,虽然有时候mail客户端会自动检测条到APOP上面),如果有好几个验证方式给你选择的话。

如果能发信,但收不到,这个时候看一下/var/log/maillog会找到答案的,一般是由于找不到libmysqlclient.so.12这个mysql库文件造成的,前面我之所以要copy到/usr/lib下就是因为这个问题

######################

安装并运行igenus

root: ~ $ tar zxvf igenus_2_20030516_snap.tgz -C /var/www/html
建temp文件夹
root: ~ $ cd /var/www/html/igenus
root: ~ $ mkdir temp
root: ~ $ chmod -R 0755 temp
root: ~ $ chown -R vpopmail:vchkpw temp

修改httpd.conf

root: ~ $ vi /etc/httpd/conf/httpd.conf

Group Apache
User Apache
修改为:
Group vchkpw
User vpopmail

AddDefaultCharset ISO-8859-1
修改为
AddDefaultCharset GB2312 使默认页面为中文,2.x的apache需要修改

root: ~ $ /etc/rc.d/init.d/httpd restart 重启apache,使修改生效

修改config_inc.php文件

root: ~ $ cd /var/www/html/config
root: ~ $ vi config_inc.php

$CFG_BASEPATH = "/var/www/html/igenus";

$CFG_MYSQL_HOST = 'localhost';
$CFG_MYSQL_USER = 'vpopmail';
$CFG_MYSQL_PASS = 'snoopy'; 改成你的密码
$CFG_MYSQL_DB = 'vpopmail';

$CFG_TEMP = $CFG_BASEPATh."/temp";

重新编制Mysql数据库表格

root: ~ $ mysql -u root -p

mysql>use vpopmail;
mysql>alter table vpopmail drop primary key;
mysql>alter table vpopmail add column pw_id int(5) NOT NULL primary key auto_increment;
mysql>create table address (id int(11) unsigned NOT NULL auto_increment,pw_id int(5) unsigned NOT NULL default '0',name varchar(64) NOT NULL default '', email varchar(128) NOT NULL default '',UNIQUE KEY id (id),KEY pw_id (pw_id)) TYPE=MyISAM;
mysql>CREATE TABLE stow (id int(11) unsigned NOT NULL auto_increment,pw_id int(5) NOT NULL default '0',name varchar(64) NOT NULL default '',http varchar(128) NOT NULL default '',memo varchar(255) NOT NULL default '',PRIMARY KEY (id)) TYPE=MyISAM PACK_KEYS=1;
mysql>quit;

编辑qmail自启动脚本

root: ~ $ vi /etc/rc.d/init.d/qmail 编辑自动运行脚本

#! /bin/sh
# chkconfig: 2345 90 90
# description: qmail (include smtp and pop3) auto start/stop scripts.

. /etc/rc.d/init.d/functions

case "$1" in

start)
echo -n "start qmail:"
/var/qmail/rc &
echo "."

echo -n "start smtp service:"
/var/qmail/smtp
echo "."

echo -n "start pop3 service:"
/var/qmail/pop3
echo "."
;;

stop)
echo "stop qmail:"
killproc qmail-send
killproc qmail-clean
killproc qmail-rspawn
killproc qmail-lspawn
killproc splogger
killproc tcpserver
;;

*)
exit 1
;;
esac

exit 0

root: ~ $ chmod 755 /etc/rc.d/init.d/qmail
root: ~ $ chkconfig --add qmail
现在只要你启动系统就会自动运行

igenus在安装和使用过程中出现错误的解决方法

1.登录时出现的错误。
编辑/usr/loal/lib/php.ini,修改:
register_globals = On

2.发邮件时出现528错误,其实这是php在编译过程中找不到/usr/sbin/sendmail文件造成的,qmail使用/var/qmail/bin/sendmail发信
解决方法:
a.添加链接
root: ~ $ ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail
b.停止apache运行
c.重新编译php即可

########################

安装ezmlm and ezmlm-idx使qmail支持邮件列表功能

1.注意:为了启用maillist的MySQL支持,你必须首先建立mysql管理用户:(Ex:user:ezmlm,pass:ezmlm)

root: ~ $ mysql -p
>use mysql;
>create database ezmlm;
>grant all on ezmlm.* to ezmlm@localhost identified by "密码";
>flush privileges;
>exit;

root: ~ $ mysqladmin -u root -psnoopyxp create ezmlm

2.ezmlm-idx包含有对ezmlm的修正和补充,他们是一个整体。

root: ~ $ cd /home/software
root: ~ $ tar -zxvf ezmlm-0.53.tar.gz
root: ~ $ tar -zxvf ezmlm-idx-0.40.tar.gz
root: ~ $ mv -Rf ezmlm-idx-0.40/* ezmlm-0.53/ 将ezmlm-idx-0.40下的文件覆盖到ezmlm-0.53下
root: ~ $ cd ezmlm-0.53
root: ~ $ patch < idx.patch
root: ~ $ patch < ezmlm-idx-0.53.400.unified_41.patch
root: ~ $ make mysql MySQL 支持
root: ~ $ make clean
root: ~ $ make man
root: ~ $ make ch_GB 汉字GB2312支持

修改conf-sqlcc文件
内容为:-I/usr/include/mysql


修改conf-sqlld
内容为: -L/usr/lib/mysql -lmysqlclient -lnsl -lm -lz
-lz是增加zip压缩支持

修改conf-bin
第一行:/var/qmail/bin/ezmlm

修改conf-man
第一行:/var/qmail/man

修改conf-qmail
第一行:/var/qmail

root: ~ $ make setup

修改/usr/local/qmail/bin/ezmlm/ezmlmrc将"To:##L@##H"修改为"To:<#L#>; @&amp;amp;lt;#H#>",主要是修改用邮件客户端收到信之后,收件人地址显示格式错误。

邮件列表收到的信息乱码解决方法:

在/home/vpopmail/domains/snoopy.gov/maillistname/下建立一个charset的文件
root: ~ $ touch charset
root: ~ $ chown vpopmail:vchkpw charset
root: ~ $ chmod go-r charset
root: ~ $ vi charset 添加一行gb2312

这样你发一份邮件到[email protected] 你收到的信息将可以正确的显示中文了!

在你建立一个基于MySQL的maillist之前,你必须保证ezmlm库中已存在一个对应的表(其实我发现没有表,ezmlm会自动建立,只是会提示错误):

Ex:你想建一个基于MySQL的maillist:testlist

root: ~ $ /var/qmail/bin/ezmlm/ezmlm-mktab -d testlist | mysql -uezmlm -pezmlm -f ezmlm

这样就在ezmlm库中为testlist建立了一系列相关表格:

+------------------------+
| Tables |
+------------------------+
| testlist |
| testlist_allow |
| testlist_allow_slog |
| testlist_cookie |
| testlist_deny |
| testlist_deny_slog |
| testlist_digest |
| testlist_digest_cookie |
| testlist_digest_mlog |
| testlist_digest_slog |
| testlist_mlog |
| testlist_mod |
| testlist_mod_slog |
| testlist_slog |
+------------------------+

你可以用一下命令察看,安装了qmailadmin后可以使用qmailadmin管理邮件列表了

root: ~ $ mysqlshow -uezmlm -pezmlm ezmlm

######################

安装autorespond

root: ~ $ tar zxvf autorespond-2.0.2.tar.gz
root: ~ $ cd autorespond-2.0.2

修改Makefile文件
将其中的INSTALL_DIR =修改为 /var/qmail/bin
root: ~ $ make
root: ~ $ make install
root: ~ $ cp autorespond /usr/local/bin

######################

安装qmailadmin
安装之前先确认你是否已经安装了vpopmail,并使用vchkpw
是否已经安装ezmlm。
是否已经安装autorespond。
确认以上的工作已完成,可以开始安装qmailadmin

root: ~ $ cd /tmp/software
root: ~ $ tar zxvf qmailadmin-1.0.6.tar.gz
root: ~ $ cp en-us qmailadmin-1.0.6/html/en
root: ~ $ cp en-us qmailadmin-1.0.6/html/en-us

注:以上两步,为了汉化qmailadmin。en-us取自iceblood的qmail安装包

root: ~ $ cd qmailadmin-1.0.6
root: ~ $ cd qmailadmin-1.0.6
root: ~ $./configure --enable-cgibindir=/var/www/cgi-bin --enable-htmldir=/var/www/html/igenus --enable-ezmlmdir=/var/qmail/bin/ezmlm (确保你的ezmlm程序文件在此目录下)
root: ~ $ make
root: ~ $ make install-strip
root: ~ $ mkdir -p /var/www/html/images/qmailadmin
root: ~ $ mv images/*.* /var/www/html/images/qmailadmin/ 复制images下的图片到/var/www/html/images/qmailadmin下

######################
安装sqwebmail

root: ~ $ cd /tmp/sofeware
root: ~ $ tar zxvf sqwebmail-3.5.0-cn.tar.gz
root: ~ $ cd sqwebmail-3.5.0
root: ~ $ ./configure --with-db=db 如果你没有安装GDBM库,那么请加上这个,默认系统如果找到了GDBM库会使用GDBM库
--enable-webpass=yes
--without-authpam
--without-authpwd
--without-authshadow
--without-authldap
--without-authuserdb
--without-authpwd
--with-authvchkpw
--with-authdaemon 激活web页面修改密码功能模块
--enable-cgibindir=/var/www/cgi-bin/sqwebmail
--enable-imagedir=/var/www/html/sqwebmail
--disable-utf7-folder-encoding 去掉IMAP文件夹编码支持
--with-cachedir=/tmp/sqwebmail 缓存目录
--with-cacheowner=bin 缓存目录所有者default: bin
--enable-mimetypes=/var/www/html/
--enalbe-mimecharset=gb2312
--enable-unicode=gb2312
root: ~ $ make configure-check
root: ~ $ make
root: ~ $ make install-strip
root: ~ $ make install-configure
root: ~ $ /usr/local/share/sqwebmail/libexec/authlib/authdaemond start

注意,以后必须启动这个进程进行身份验证,发现安装sqwebmail后,这个进程不启动那么我的邮件系统就没法登陆,总是说密码验证错误,qmailadmin倒可以登陆

su -c "/usr/local/share/sqwebmail/cleancache.pl" bin


现在,重起你主机系统,设置你的outlook或者foxmail.接受邮件了,也可以通过webmail访问你的mail系统了
http://localhost/cgi-bin/sqwebmail/sqwebmail

通过webmail接受你的邮件信息,sqwebmail我只是装上测试一下,看看效果,它对中文支持比较差,也没有比较好的中文版本,大家还是觉得用igenus比较好
http://localhost/cgi-bin/qmailadmin 通过web方式管理和添加用户了

补充:在/home/vpopmail/domains/snoopy.gov下面建立一个.qmailadmin-limits文件,这个文件本身没有在里面写
maxpopaccounts 100
default_quota 10485760

这样用qmailadmin添加账号的最大数目就是100,每个邮箱的配额就是10485760,10M

此贴只适合AS3,其他系统没试过,因为需要打的补丁真的太多了,贴中有不足的地方请兄弟提出!有问题请跟贴!