Nginx日志分析工具GoAccess,有没有好用的Nginx日志分析工具?
- 运维笔记
- 2024-09-23
- 706热度
- 0评论
官方地址: https://goaccess.io
GoAccess
GoAccess 是一款开源的实时 Web 日志分析工具,支持Nginx等多种日志格式,支持分析并导出HTML
1.安装
直接通过yum安装:
# 安装依赖库
yum install -y GeoIP-devel ncurses-devel
# 安装GoAccess
yum install goaccess
修改配置文件,一般在/etc/goaccess/goaccess.conf:
time-format %H:%M:%S
date-format %d/%b/%Y
# NCSA Combined Log Format
log-format %h %^[%d:%t %^] "%r" %s %b "%R" "%u"
2.使用
设置语言为中文,分析指定的Nginx日志文件,并导出html:
LANG="zh_CN.UTF-8" && awk '$4 ~ /23\/Sep\/2024/' /www/wwwlogs/site.log | goaccess -a -c -d -p /etc/goaccess/goaccess.conf --html-prefs '{"autoHideTables":true,"layout":"vertical","perPage":20,"theme":"bright","showTables":true,"requests":{"plot":{"metric":"hits-visitors","chartType":"bar"}}}' > /www/wwwlogs/log.html
- -a 或 --agent-list:显示访问者使用的浏览器和操作系统信息。
- -c 或 --http-protocol:显示 HTTP 协议的版本。
- -d 或 --no-term-resolver:不解析终端分辨率。
- -p 或 --config-file:指定 GoAccess 的配置文件路径,这里是 /etc/goaccess/goaccess.conf。
- --html-prefs:设置 HTML 输出的偏好设置。
3.定时导出
创建如下的脚本:
#!/bin/bash
#页面转换为中文
LANG="zh_CN.UTF-8"
# 定义日志文件和输出文件的路径
LOG_FILE="/www/wwwlogs/webapi.log"
TEMP_OUTPUT_FILE="/www/nginx/online.html"
OUTPUT_FILE="/www/nginx/report.html"
TEMP_FILE="/tmp/webapi_23sep2024.log"
# 使用 awk 筛选出2024年9月23日的日志行,并保存到临时文件
awk '$4 ~ /23\/Sep\/2024/' "$LOG_FILE" > "$TEMP_FILE"
# 检查临时文件是否为空
if [ -s "$TEMP_FILE" ]; then
# 使用 goaccess 分析临时文件
LANG="zh_CN.UTF-8" && goaccess -a -c -d -p /etc/goaccess/goaccess.conf --html-prefs '{"autoHideTables":true,"layout":"vertical","perPage":20,"theme":"bright","showTables":true,"requests":{"plot":{"metric":"hits-visitors","chartType":"bar"}}}' "$TEMP_FILE" > "$TEMP_OUTPUT_FILE"
# 检查 goaccess 是否成功执行并输出结果
if [ $? -eq 0 ]; then
cp "$TEMP_OUTPUT_FILE" "$OUTPUT_FILE"
echo "报告已成功生成并保存到 $OUTPUT_FILE"
else
echo "生成报告时发生错误。"
fi
else
echo "没有找到2024年9月23日的日志数据。"
fi
# 清理临时文件
rm -f "$TEMP_FILE"
4.演示
实时数据,5分钟更新一次:https://nicen.cn/logs.html