日常工作需要用到,shell语句用于分析定位生产问题,本次做个记录
# 将日志先拷贝到当前目录
cp /tmp/Nginx.log .
本次目标是: 找出log中的404 500的报错
#使用管道取出相关日志
less nginx.log
data:image/s3,"s3://crabby-images/f2101/f21015a68e6cdac0b6f8b7d6d75cd5b671a0fc74" alt="Linux 进阶语句"
通过/ 查询得知 状态码处于第9个字段
#使用 awk 筛选出第九个字段的全部内容
less nginx.log | awk '{print $9}'
对应结果集太多
# 使用sort排序 uniq -c 去重 统计
less nginx.log | awk '{print $9}'| sort | uniq -c
data:image/s3,"s3://crabby-images/56787/5678799fda0214abb12f7f54b628457dc20fb20d" alt="Linux 进阶语句"
总有以上几种状态码,需要再次筛选
#使用 ~正则 匹配日志400和500状态相关的 $0打印所有行信息
less nginx.log | awk '$9~/500|404/{print $0}'
data:image/s3,"s3://crabby-images/a3bb1/a3bb193c3c4a7a959b145cb0c6bd2df39276ed7b" alt="Linux 进阶语句"
找出500错误时候的上下文,找出500错误的前两行 考察grep高级用法
可以使用grep -b
- -b 或 --byte-offset : 在显示符合样式的那一行之前,标示出该行第一个字符的编号。
- -B<显示行数> 或 --before-context=<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前的内容。
grep -B 2 '500' nginx.log
data:image/s3,"s3://crabby-images/b53d0/b53d019fd75c18e7bb717cf8cdd2e2bc7ee7b3bb" alt="Linux 进阶语句"
统计前十的ip,分别打印ip和出现次数
首先查询到日志:cat nginx.log
data:image/s3,"s3://crabby-images/f631b/f631b17cd59efcfe7a12bc69fa20974b230e9feb" alt="Linux 进阶语句"
通过日志分析的得知ip处于日志中第一个字段位置
#利用管道符,拼接awk分割,打印出的ip信息
cat nginx.log|awk {print $1}
data:image/s3,"s3://crabby-images/7395e/7395ef2b3890dbd1b5bc400a184beb0f27b8977d" alt="Linux 进阶语句"
管道符拼接
然后使用sort对结果进行排序
使用uniq -c 去统计次数
- -c或--count 在每列旁边显示该行重复出现的次数。
data:image/s3,"s3://crabby-images/7518d/7518da321fe933806ef3eed8529f3d4b193d57d1" alt="Linux 进阶语句"
使用sort -nr 检查排序(以前十倒序排序)
- -n 依照数值的大小排序
- -r 以相反的顺序来排序
使用head -n 10 筛选数据只有 十行
data:image/s3,"s3://crabby-images/ff480/ff480d79c2b0cfd7c93c6e6b8f1fb4a77ca2099e" alt="Linux 进阶语句"