设为首页 收藏本站
查看: 1429|回复: 0

[经验分享] 分析工具Awstats实战之Nginx篇-分析结果动态化

[复制链接]

尚未签到

发表于 2019-1-30 08:24:22 | 显示全部楼层 |阅读模式
  上一篇博文“分析工具Awstats实战之Nginx篇-分析结果静态化 http://www.linuxidc.com/Linux/2013-10/92150.htm”介绍了如何将awstats的日志分析信息用静态页面来进行显示,不过显示效果肯定没有动态的好啦。本篇博文将带大家一起来部署动态的分析结果查阅。
  环境:
  CentOS 6.4
  ip:192.168.1.113
  域名:www.linuxidc.com(server和client都通过hosts文件解析)
  nginx-1.2.9 编译安装,路径/usr/local/nginx,服务开启状态
  日志记录格式为nginx默认的,切勿更改,否则会造成awstats无法分析日志。
  log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  '$status $body_bytes_sent "$http_referer" '
  '"$http_user_agent" "$http_x_forwarded_for"';
  awstats-7.2.tar.gz CPAN-2.00.tar.gz FCGI-0.74.tar.gz FCGI-ProcManager-0.24.tar.gz
  必须有perl-devel,不然无法编译FCGI。
  一、日志自动切割
  对于nginx的日志切割,由于没有像apache一样去用cronolog工具,这里我们就写一个脚本,让它可以在每天00:01自动执行,切割昨天的日志(交由awstats分析),压缩前天的日志(压缩日志可减小存储空间,为防止awstats没有分析完就被压缩,所以只压缩前天的日志)。
  vim /server/scripts/cut_nginx_log.sh
  输入以下内容:
  #!/bin/sh
  yesterday=`date -d "yesterday" +"%Y%m%d"`
  before_yesterday=`date -d "-2 day" +"%Y%m%d"`
  Nginx_Dir="/usr/local/nginx"
  Nginx_logs="/app/logs"
  Log_Name="www_access"
  cd /tmp
  [ -d $Nginx_Logs ] && cd $Nginx_logs || exit 1
  [ -f $Log_Name.log ] && /bin/mv $Log_Name.log ${Log_Name}_${yesterday}.log || exit 1
  if [ $? -eq 0 -a -f $Nginx_Dir/logs/nginx.pid ]
  then
  kill -USR1 `cat $Nginx_Dir/logs/nginx.pid`
  fi
  [ -f  ${Log_Name}_${before_yesterday}.log ] && /usr/bin/gzip ${Log_Name}_${before_yesterday}.log|| exit 1
  执行crontab -e将该脚本加入定时任务中
  1 0 * * * /bin/sh /server/scripts/cut_nginx_log.sh >/dev/null 2>&1
  这样每天凌晨00:01就能自动实现日志的切割,压缩等功能了。
  因为本次实验下的nginx此时已经有日志了,另外为了后文awstats能对切割过的日志进行分析,所以这里我们要运行一下此脚本,来将现有日志进行切割生成昨天的日志方便后文操作。
  /bin/sh /server/scripts/cut_nginx_log.sh >/dev/null 2>&1
  二、配置FCGI
  1、安装CPAN
  wget http://search.cpan.org/CPAN/authors/id/A/AN/ANDK/CPAN-2.00.tar.gz
  tar zxf CPAN-2.00.tar.gz
  cd CPAN-2.00
  perl Makefile.PL
  make && make install
  2、安装FCGI和FCGI::ProcManager
  wget http://search.cpan.org/CPAN/authors/id/F/FL/FLORA/FCGI-0.74.tar.gz
  tar zxf FCGI-0.74.tar.gz
  cd FCGI-0.74
  第一种安装方法:perl -MCPAN -e 'install FCGI'
  第二种安装方法:perl Makefile.PL
  make&&make install
  wget http://search.cpan.org/CPAN/authors/id/B/BO/BOBTFISH/FCGI-ProcManager-0.24.tar.gz
  tar zxf FCGI-ProcManager-0.24.tar.gz
  cd FCGI-ProcManager-0.24
  第一种安装方法:perl -MCPAN -e 'install FCGI::ProcManager'
  第二种安装方法:perl Makefile.PL
  make&&make install
  在执行第一种安装方法的时候,一定是全程自动滚动下来提示OK的。如果出现提示你输入yes之类的,你需要按提示操作完之后,再运行第二次直到全程自动滚动下来提示OK才为完成安装。或者你就用第二种方法来执行安装。
  3、创建FCGI启动文件
  vi /usr/local/nginx/sbin/fcgi      #此处按个人习惯命名
  #!/usr/bin/perl
  use FCGI;
  #perl -MCPAN -e 'install FCGI'
  use Socket;
  use POSIX qw(setsid);
  #use Fcntl;
  require 'syscall.ph';
  &daemonize;
  #this keeps the program alive or something after exec'ing perl scripts
  END() { } BEGIN() { }
  *CORE::GLOBAL::exit = sub { die "fakeexit\nrc=".shift()."\n"; };
  eval q{exit};
  if ($@) {
  exit unless $@ =~ /^fakeexit/;
  };
  &main;
  sub daemonize() {
  chdir '/'                or die "Can't chdir to /: $!";
  defined(my $pid = fork)  or die "Can't fork: $!";
  exit if $pid;
  setsid                    or die "Can't start a new session: $!";
  umask 0;
  }
  sub main {
  #$socket = FCGI::OpenSocket( "127.0.0.1:8999", 10 );
  $socket = FCGI::OpenSocket( "/usr/local/nginx/fastcgi_temp/perl_cgi-dispatch.sock", 10 );
  #use UNIX sockets - user running this script must have w access to the 'nginx' folder!!
  $request = FCGI::Request( \*STDIN, \*STDOUT, \*STDERR, \%req_params, $socket );
  if ($request) { request_loop()};
  FCGI::CloseSocket( $socket );
  }
  sub request_loop {
  while( $request->Accept() >= 0 ) {
  #processing any STDIN input from WebServer (for CGI-POST actions)
  $stdin_passthrough ='';
  $req_len = 0 + $req_params{'CONTENT_LENGTH'};
  if (($req_params{'REQUEST_METHOD'} eq 'POST') && ($req_len != 0) ){
  my $bytes_read = 0;
  while ($bytes_read < $req_len) {
  my $data = '';
  my $bytes = read(STDIN, $data, ($req_len - $bytes_read));
  last if ($bytes == 0 || !defined($bytes));
  $stdin_passthrough .= $data;
  $bytes_read += $bytes;
  }
  }
  #running the cgi app
  if ( (-x $req_params{SCRIPT_FILENAME}) && #can I execute this?
  (-s $req_params{SCRIPT_FILENAME}) && #Is this file empty?
  (-r $req_params{SCRIPT_FILENAME})    #can I read this file?
  ){
  pipe(CHILD_RD, PARENT_WR);
  my $pid = open(KID_TO_READ, "-|");
  unless(defined($pid)) {
  print("Content-type: text/plain\r\n\r\n");
  print "Error: CGI app returned no output - Executing $req_params
  {SCRIPT_FILENAME} failed !\n";
  next;
  }
  if ($pid > 0) {
  close(CHILD_RD);
  print PARENT_WR $stdin_passthrough;
  close(PARENT_WR);
  while(my $s = ) { print $s; }
  close KID_TO_READ;
  waitpid($pid, 0);
  } else {
  foreach $key ( keys %req_params){
  $ENV{$key} = $req_params{$key};
  }
  # cd to the script's local directory
  if ($req_params{SCRIPT_FILENAME} =~ /^(.*)\/[^\/]+$/) {
  chdir $1;
  }
  close(PARENT_WR);
  close(STDIN);
  #fcntl(CHILD_RD, F_DUPFD, 0);
  syscall(&SYS_dup2, fileno(CHILD_RD), 0);
  #open(STDIN, "

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-669388-1-1.html 上篇帖子: Awstats流量监控nginx日志全过程 下篇帖子: ubuntu12TSL安装awstats日志分析软件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表