一、首先将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)}

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

shell脚本分析apache日志状态码的更多相关文章

  1. shell脚本分析nginx日志

    shell脚本分析nginx日志: name=`awk -F ',' '{print $13":"$32}' $file | awk -F ':' '{print $4}'`ech ...

  2. shell脚本之变量与状态码

    目录: 前言 如何创建一个脚本 脚本调试 变量相关 变量的命令规则 bash中变量的种类 本地变量 环境变量 只读和位置变量 位置变量 查询变量 进程的退出状态与状态码 前言 在linux管理中,sh ...

  3. shell脚本分析 nginx日志访问次数最多及最耗时的页面

    当服务器压力比较大,跑起来很费力时候.我们经常做站点页面优化,会去查找那些页面访问次数比较多,而且比较费时. 找到那些访问次数高,并且比较耗时的地址,就行相关优化,会取得立竿见影的效果的. 下面是我在 ...

  4. 如何用shell脚本分析网站日志统计PV、404、500等数据

    以下shell脚本能统计出网站的总访问量,以及404,500出现的次数.统计出来后,可以结合监控宝来进行记录,进而可以看出网站访问量是否异常,是否存在攻击.还可以根据查看500出现的次数,进而判断网站 ...

  5. shell脚本实现网站日志分析统计

    如何用shell脚本分析与统计每天的访问日志,并发送到电子邮箱,以方便每天了解网站情况.今天脚本小编为大家介绍一款不错的shell脚本,可以实现如上功能. 本脚本统计了:1.总访问量2.总带宽3.独立 ...

  6. elk系列7之通过grok分析apache日志【转】

    preface 说道分析日志,我们知道的采集方式有2种: 通过grok在logstash的filter里面过滤匹配. logstash --> redis --> python(py脚本过 ...

  7. Hadoop的shell脚本分析

    你会发现hadoop-daemon.sh用于启动单独的本机节点 而hadoop-daemons.sh 会批量的ssh到别的机器启动 前记: 这些天一直学习hadoop,学习中也遇到了许多的问题,主要是 ...

  8. 如何分析apache日志[access_log(访问日志)和error_log(错误日志)]

    如何分析apache日志[access_log(访问日志)和error_log(错误日志)] 发布时间: 2013-12-17 浏览次数:205 分类: 服务器 默认Apache运行会access_l ...

  9. shell 在手分析服务器日志【转】

    自己的小网站跑在阿里云的 ECS 上面, 偶尔也去分析分析自己网站服务器日志,看看网站的访问量.看看有没有黑阔搞破坏!于是收集,整理一些服务器日志分析命令,大家可以试试! awk '{print $1 ...

随机推荐

  1. datatime模块

    https://www.cnblogs.com/cindy-cindy/p/6720196.html

  2. Echart自定义属性3

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. “全栈2019”Java第一百一十章:局部内部类与匿名内部类区别详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  4. powerdesign设计、实现简单的数据库模型

    1,新建CDM,打开powerdesign,选择Categories----Infoomation------Conceptual Data.开始画图,如果此时如表示关系的图标是灰色的.Tools-- ...

  5. 【微信小程序】——rpx、px、rem等尺寸间关系浅析

    最近开发微信小程序,在写样式表的时候发现用PX的效果不太理想,而官方文档用rpx来做响应式布局单位,就仔细研究了下,在此做个小总结: 这里先引用官方定义的尺寸单位‘rpx’:可以根据屏幕宽度进行自适应 ...

  6. wireshark 1.10.0 编译 及 协议解析部分的一些变化

    wireshark不久前升级到1.10.0稳定版,这个版本正如其版本号一样,相比1.8.x有较大变化. 我们先说说在windows下编译的问题,1.8.4/1.8.6版本的编译见我的文章:http:/ ...

  7. SpringBoot + Scala环境部署

    在pom.xml文件中添加: <dependencies>中 <!-- 添加Scala依赖 --> <dependency> <groupId>org. ...

  8. CSS01--概述与选择器

    CSS:Cascading Style Sheets,层叠样式表.我们之前已经说过,HTML解决的是网页内容(结构)的问题,而CSS立足于网页的表现方面的问题,则样式定义如何显示HTML标签,js负责 ...

  9. 用 Hystrix 构建高可用服务架构

    1 hystrix是什么 在分布式系统中,每个服务都可能会调用很多其他服务,被调用的那些服务就是依赖服务,有的时候某些依赖服务出现故障也是很正常的. Hystrix 可以让我们在分布式系统中对服务间的 ...

  10. spark持久化

    spark持久化:cache .persist.checkpoint 一.cache持久化 cache实际上是persist的一种简化方式,是一种懒执行的,执行action类算子才会触发,cahce后 ...