我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Shell脚本实现apache日志中的状态码分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Shell脚本实现apache日志中的状态码分析

一、首先将apache日志按天切割

vi /etc/httpd/conf/httpd.conf

        ErrorLog "|rotatelogs /var/log/httpd/%Y%m%derror_log 86400 480"

       CustomLog "|rotatelogs /var/log/httpd/%Y%m%daccess_log 86400 480" combined

二、重启apache服务

service httpd restart

##################apahce日志服务器按天切割完毕######################

三、分析生成的apache日志状态码(等待了一天的日志)

***日志文件为20111228access_log

       vi http.sh 

       #!/bin/bash

       total=`cat 20111228access_log|wc -l`

      array=(`cat 20111228access_log |awk '{print $9}'|sort|uniq -c|sort -n`)

      len=${#array[@]}

      echo "####################http状态码统计###########################"

      echo "总的连接数:$total"

             for ((i=0;i<$len;i=i+2))

                {

                   echo "########################################################"

                           echo ${array[$i]}:${array[$i+1]}

                   echo "########################################################"

                            echo ${array[$i+1]}占连接数的比例是:`awk 'BEGIN{printf "%.6f%n",('${array[$i]}'/'${total}'*100)}'`

                 }

执行脚本结果(以百分号表示):

sh http.sh 

####################http状态码统计###########################

总的连接数:688965

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

1:303

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

303占连接数的比例是:0.000145%

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

1:416

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

416占连接数的比例是:0.000145%

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

2:299

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

299占连接数的比例是:0.000290%

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

8:501

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

501占连接数的比例是:0.001161%

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

145:403

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

403占连接数的比例是:0.021046%

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

197:400

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

400占连接数的比例是:0.028594%

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

738:206

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

206占连接数的比例是:0.107117%

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

7307:404

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

404占连接数的比例是:1.060576%

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

9213:302

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

302占连接数的比例是:1.337223%

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

30574:301

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

301占连接数的比例是:4.437671%

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

201197:304

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

304占连接数的比例是:29.202790%

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

439582:200

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

200占连接数的比例是:63.803241%

########################简单讲解#########################

array=(`cat 20111228access_log |awk '{print $9}'|sort|uniq -c|sort -n`)

  ###这个拿出来是一个数组了

len=${#array[@]} 

 ###这个是数组的长度

echo ${array[$i]}:${array[$i+1]}

###这个是以for循环输入状态码和状态码的连接数

awk 'BEGIN{printf "%.6f%n",('${array[$i]}'/'${total}'*100)}

###以百分比计算各个状态码大约占的连接数

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Shell脚本实现apache日志中的状态码分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Shell脚本实现apache日志中的状态码分析

一、首先将apache日志按天切割vi /etc/httpd/conf/httpd.confErrorLog "|rotatelogs /var/log/httpd/%Y%m%derror_log 86400 480"CustomLog "
2022-06-04

怎么用Shell脚本实现apache日志中的状态码

本篇内容主要讲解“怎么用Shell脚本实现apache日志中的状态码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Shell脚本实现apache日志中的状态码”吧!一、首先将apache日
2023-06-09

Shell脚本实现分析apache日志中ip所在的地区

查询ip地址所用的组件wget http://rfyiamcool.googlecode.com/files/nali-0.1.tar.gz tar zxvf nali-0.1.tar.gz cd nali-0.1 ./configu
2022-06-04

如何实现并分析Shell脚本apache日志中ip所在的地区

这篇文章主要讲解了“如何实现并分析Shell脚本apache日志中ip所在的地区”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现并分析Shell脚本apache日志中ip所在的地区”吧
2023-06-09

shell脚本怎么实现的网站日志分析统计

本篇内容主要讲解“shell脚本怎么实现的网站日志分析统计”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“shell脚本怎么实现的网站日志分析统计”吧!写了个shell脚本,可以用来统计每天的访问
2023-06-09

Linux中shell脚本输出日志的示例分析

这篇文章给大家分享的是有关Linux中shell脚本输出日志的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、日志方法简介:#日志名称log="./upgrade.log" #操作日志存放路径 fsi
2023-06-09

shell脚本实现分日志级别输出的方法

shell脚本如何优雅的记录日志信息,下面让我们一步一步,让shell脚本的日志也变得高端起来,实现如下功能 ①设定日志级别,实现可以输出不同级别的日志信息,方便调试 ②日志格式类似为:[日志级别] 时间 funcname:函数名 [li
2022-06-04

Linux下shell脚本监控Tomcat的状态并实现自动启动的示例分析

这篇文章主要介绍Linux下shell脚本监控Tomcat的状态并实现自动启动的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.编写Shell脚本monitor.sh#!/bin/sh# func:自动监控
2023-06-09

shell脚本实现的网站日志分析统计(可以统计9种数据)

写了个shell脚本,可以用来统计每天的访问日志,并发送到电子邮箱,方便每天了解网站情况。脚本统计了:1、总访问量2、总带宽3、独立访客量4、访问IP统计5、访问url统计6、来源统计7、404统计8、搜索引擎访问统计(谷歌,百度)9、搜索
2022-06-04

如何在Linux系统中通过PHP脚本实现日志分析

引言:日志分析对于网站运营和系统管理来说是非常重要的一项任务。通过对日志进行分析,我们可以了解用户行为、网站访问情况以及系统运行状态等信息,从而为网站优化和系统调整提供依据。在Linux系统中,可以使用PHP脚本来实现日志分析,并根据具体需
2023-10-21

shell脚本中使用iconv实现批量文件转码的代码分享

在开发中,我们经常需要对N多文件编码进行更改,iconv只能对单文件的进行更改,怎么办呢?我们写一个shell脚本来解决这个问题。 例子一:使用shell脚本实现批量转码的操作。#!/bin/sh # convertCodeFilePat
2022-06-04

linux中shell脚本实现root切换到普通用户执行脚本或命令的示例分析

这篇文章将为大家详细讲解有关linux中shell脚本实现root切换到普通用户执行脚本或命令的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。需求:安装deb包,设置程序安装后启动,不需要root
2023-06-09

编程热搜

目录