Chinaunix首页 | 论坛 | 博客
  • 博客访问: 384078
  • 博文数量: 87
  • 博客积分: 2810
  • 博客等级: 少校
  • 技术积分: 825
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-28 22:34
文章分类

全部博文(87)

文章存档

2010年(25)

2009年(43)

2008年(19)

分类: LINUX

2009-04-22 23:39:50

安装apache的时候一定要把suexec、cgi安装上,不然后面你再安装suexec就很容易出错,这个问题很头大。所以开始安装的时候一定要把suexec安装上,不管用不用得上,先装上。
查看apache是否启用了suexec, -D SUEXEC_BIN="/usr/local/sbin/suexec"
FMS# httpd -V
Server version: Apache/2.2.6 (FreeBSD)
Server built:   Mar  2 2008 18:14:00
Server's Module Magic Number: 20051115:5
Server loaded:  APR 1.2.11, APR-Util 1.2.10
Compiled using: APR 1.2.11, APR-Util 1.2.10
Architecture:   32-bit
Server MPM:     Prefork
  threaded:     no
    forked:     yes (variable process count)
Server compiled with....
 -D APACHE_MPM_DIR="server/mpm/prefork"
 -D APR_HAS_SENDFILE
 -D APR_HAS_MMAP
 -D APR_USE_FLOCK_SERIALIZE
 -D APR_USE_PTHREAD_SERIALIZE
 -D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
 -D APR_HAS_OTHER_CHILD
 -D AP_HAVE_RELIABLE_PIPED_LOGS
 -D DYNAMIC_MODULE_LIMIT=128
 -D HTTPD_ROOT="/usr/local"
 -D SUEXEC_BIN="/usr/local/sbin/suexec"
 -D DEFAULT_PIDLOG="/var/run/httpd.pid"
 -D DEFAULT_SCOREBOARD="/var/run/apache_runtime_status"
 -D DEFAULT_LOCKFILE="/var/run/accept.lock"
 -D DEFAULT_ERRORLOG="/var/log/httpd-error.log"
 -D AP_TYPES_CONFIG_FILE="etc/apache22/mime.types"
 -D SERVER_CONFIG_FILE="etc/apache22/httpd.conf"
查看suexec的目录路径
FMS# suexec -V
 -D AP_DOC_ROOT="/usr/local/www/data"
 -D AP_GID_MIN=1000
 -D AP_HTTPD_USER="www"
 -D AP_LOG_EXEC="/var/log/httpd-suexec.log"
 -D AP_SAFE_PATH="/usr/local/bin:/usr/local/bin:/usr/bin:/bin"
 -D AP_UID_MIN=1000
 -D AP_USERDIR_SUFFIX="public_html"
更改 CGI 文件的用户及组属性
# cd /usr/local/www/data/extmail
# chown -R vuser:vgroup cgi
# cd /usr/local/www/data/extman
# chown -R vuser:vgroup cgi
/usr/local/etc/rc.d/apache22 reload

其中碰到的一些问题及解决办法
[2008-08-11 16:11:05]: uid: (1000/vuser) gid: (1000/1000) cmd: index.cgi
[2008-08-11 16:11:05]: cannot get docroot information (/usr/local/www/data)
[2008-08-11 16:11:16]: uid: (1000/vuser) gid: (1000/1000) cmd: index.cgi
[2008-08-11 16:11:16]: cannot get docroot information (/usr/local/www/data)

FMS# ll /usr/local/sbin/suexec
-rwsr-xr-x  1 root  wheel  12911 Mar  2 18:15 /usr/local/sbin/suexec
以下是extmail+suexec+cgi的apache配置文件中的配置:
######### Web Mail System Configure ##########################

     ServerName mail9ye.3322.org
     DocumentRoot /usr/local/www/data/extmail/html
   
        Options Indexes
        Allow from all
   

    SuexecUserGroup vuser vgroup
      ScriptAlias /extmail/cgi /usr/local/www/data/extmail/cgi
      Alias /extmail /usr/local/www/data/extmail/html/
  
         AllowOverride None
         Options Indexes FollowSymLinks
         Order allow,deny
         Allow from all
  
  
         Options Indexes
         Allow from all
  
      ScriptAlias /extman/cgi /usr/local/www/data/extman/cgi
      Alias /extman /usr/local/www/data/extman/html/
  
        AllowOverride None
        Options Indexes FollowSymLinks
        Order allow,deny
        Allow from all
   
   ErrorLog "/var/log/extmail.log"   
 
成功将amavisd日志单独写入amavisd.log文件
可能有人会笑话我,这么简单!
我使用freebsd6.2,fengyong的自动安装,23000多学生帐户,经过几个月的磨合,垃圾邮件基本没有误伤了,有需要交流经验的朋友,呵呵!!
原来amavisd_new是将日志写入maillog的,每次查找垃圾邮件问题都十分不方便,今天决心给它独立出来,成功了:
1.在/usr/local/etc/amavisd.conf中,将
#$syslog_facility = 'mail';   # Syslog facility as a string
改成了
$syslog_facility = 'local0';   # Syslog facility as a string
2.在/etc/syslog.conf中增加了一行:
local0.info    /var/log/amavisd.log
3.生成一下日志文件:touch /var/log/amavisd.log
4.重启一下amavisd和syslogd服务:
/usr/local/etc/rc.d/amavisd restart
/etc/rc.d/syslogd restart
5.验证一下,成功了:tail -f /var/log/amavisd.log 看到日志在增加。
呵呵,希望对你有用!
改进:
根据上面的配置,amavisd的日志还会写入到messages中,经过一番实验测试,做如下更改就可以解决。
修改/etc/syslog.conf
*.notice;authpriv.none;kern.debug;lpr.info;mail.crit;news.err   /var/log/messages
改为
authpriv.none;kern.debug;lpr.info;mail.crit;news.err    /var/log/messages
再添加一行
*.notice                                        /var/log/notice.log
Touch /var/log/notice.log
这样就不会影响到系统记录*.notice日志了,当然amavisd的日志也会记录到/var/log/notice.log中去,但是这样就方便看messages日志了,毕竟这个日志是我们的重要日志。
 
mail系统要连接外部数据库需要修改如下几个文件
/usr/local/etc/postfix下面的mysql虚拟域文件
/usr/local/etc/authllib下面的authmysqlrc文件中的mysql地址
还有就是webmail配置文件中的mysql地址需要更改,一共两个配置文件
还有就是外部数据库需要配置iptables允许访问3306端口
extmail数据库授权需要改为相应该的IP地址
阅读(984) | 评论(0) | 转发(0) |
0

上一篇:Cacti监控硬盘IO--有图无数据

下一篇:mail.pl

给主人留下些什么吧!~~