nginx的轻量级日志分析工具GOACCESS
off999 2025-10-02 05:50 25 浏览 0 评论
由于日志很多,不知道怎么处理,这几天一直在找一个能分析nginx日志的工具,知道目前网站的情况,找到了GoAccess - Downloads,部署简单,还有界面展示,准备用这个。部署简单,如果nginx用原生的COMBINED格式的额日志,那么整个流程会很简单,主要功夫浪费在了自定义的nginx日志格式写出相匹配的goaccess.conf中的log_format的正则格式。
部署下载
从GoAccess - Downloads下载goaccess-1.9.4.tar.gz文件,上传到nginx部署的服务上进行安装。
# 解压源码包
tar -zxvf /tmp/goaccess-1.9.4.tar.gz -C /tmp
cd /tmp/goaccess-1.9.4
# 配置编译选项(可选:--enable-utf8 启用 UTF-8 支持,--with-zlib 启用压缩日志)
./configure --enable-utf8 --with-zlib
# 编译并安装(需 sudo)
make && sudo make install
# 验证安装
goaccess --version查看版本出现内容,即安装成功了。其中它的配置文件在
/usr/local/etc/goaccess/goaccess.conf位置。进入此文件,打开三个注解,time_format、date-format、log-foramt,保存退出。
修改配置文件并页面查看结果
需要提前把nginx.conf中的access.log文件设置为COMBINED格式,即在nginx.conf的http模板中设置如下
access_log /home/data/wwwlogs/nginx/http-access.log combined;然后执行以下操作,看是否报错,如果报错,大概率是ngin日志格式无法解析
goaccess /home/data/wwwlogs/nginx/http_access.log -p /usr/local/etc/goaccess/goaccess.conf没有错误,就可以看到控制台展示,如下:
接下来为了方便查看,可以设置生成页面,配置nginx进行查看了。
写一个shell文件,生成一个html文件,格式如下:
# !/bin/bash goaccess.sh
LANG="zh_CN.UTF-8" #页面转换为中文
/usr/local/bin/goaccess /home/data/wwwlogs/nginx/http-access.log -o /home/data/wwwlogs/index.html -p /usr/local/etc/goaccess/goaccess.conf
对这个文件授予执行权限chmod +x goaccess.sh,然后执行crontab -e,写如下内容
30 * * * * /bin/bash /home/data/script/goaccess.sh和vim一样,保存退出即可。下面开始配置nginx,把统计页面透出去查看,在nginx的配置中增加新的配置文件goaccess-8099.conf,内容如下:
server {
listen 8099;
server_name 192.168.118.6:8099;
# Allow special characters in headers
ignore_invalid_headers off;
# Allow any size file to be uploaded.
# Set to a value such as 1000m; to restrict file size to a specific value
client_max_body_size 0;
# Disable buffering
proxy_buffering off;
proxy_request_buffering off;
location / {
alias /home/data/wwwlogs/;
index index.html index.htm;
try_files $uri $uri/ /index /index.html;
}
}对nginx进行reload后,即可打开页面查看。
注意: 以上的nginx的日志是默认的没有修改。
但是在实际工作中会对nginx.conf的access.log进行个性化自定义,那么就需要相匹配goaccess.conf的配置。目前有两种解决方式。
- 再增加一个access.log的日志,不影响自定义的,但是性能会有所降低。如下图:
- 根据nginx的日志格式,写出相匹配的goaccess.conf的log_foramt日志的正则
nginx.conf的http的日志格式:
log_format main '$time_local || $remote_addr || $upstream_addr || $status || $request_time || $upstream_status || $upstream_response_time '
' || $upstream_cache_status || $body_bytes_sent || $http_referer '
' || $remote_user || $http_user_agent '
' || $http_x_forwarded_for || $request';
相匹配的goaccess.conf的配置文件:
# 日志格式定义:使用 %d:%t %^ 来匹配日期时间字段(包括时区)
log-format %d:%t %^||%h||%v||%s||%T||%S||%R||%^||%b||%^||%^||%{Referer}i||%u||%{X-Forwarded-For}i||%r
# 日期格式:匹配日期部分(如 24/Sep/2025)
date-format %d/%b/%Y
# 时间格式:匹配时间部分(如 15:54:43)
time-format %H:%M:%S
# Locale 设置:确保英文月份缩写被正确解析
#locale en_US.UTF-8
其余操作都是一样的。
相关推荐
- 显卡参数对比(rtx50系列显卡参数对比)
-
在规格方面:显卡容量大(大容量显卡在大型游戏中比较有用);显卡速度快(比如DDR5比DDR3快);核心频率高(比如4830在500MHZ左右,4870能到700多)这是显卡很重要的参数;还有流处理器...
- n卡驱动下载官网(n卡驱动官网网址)
-
1可能下载不了。2可能的原因是网速不稳定或者网络连接不畅,还有就是可能是服务器维护或者更新的原因。3如果下载不了,可以尝试换一个时间或者尝试使用其他的下载方式或者下载其他版本的驱动。另外,也可以...
- android模拟器下载安装(安卓模拟器软件下载)
-
电脑版安卓模拟器可以通过网上下载并安装。首先选择一个安卓模拟器,比如NoxPlayer、BlueStacks、LDPlayer等,然后在官网或其他可靠的下载网站下载对应的安装包。下载完成后,双击安装包...
- win7明明是管理员却没有权限
-
答:win7没有管理员权限的解决方法。1.为Windows7的右键菜单添加取得所有权的菜单:具体实现的方法不难,将以下内容另存为文本文件; 2.然后修改该文件的扩展名为.reg,双击导...
- 电脑c盘格式化了怎么装系统(电脑c盘格式化后还能用吗)
-
C盘只有格式化才能中心装系统吗?不是的。C盘格式化是为了让C盘更清洁,这样装了的系统比较纯净的。没有系统来及,用起来更是的速度快。格式化(format)是指对磁盘或磁盘中的分区(partition)进...
- 佳能(中国)官网下载(佳能(中国)官网下载appstore)
-
需要先进入佳能官网的下载页面,选择手机APP下载选项,根据手机操作系统的不同选择相应的下载链接即可成功下载佳能手机APP。下载链接通常会在网站的首页或者是产品页面上提供。总的来说,下载佳能手机APP非...
- c盘右边有个恢复分区怎么删除
-
1、从网上下载“分区助手专业6.2(或5.6)”,它能无损分区,下载后打开按提示安装,点击分区助手桌面快捷方式图标,打开分区助手专业版6.2主界面。2、右击要调出空间的分区,如E,选“分配自由空间”,...
- 电脑插着电源却不充电怎么办
-
电脑插上电源但无法充电可能有以下原因:1.电池没有完全安装,需要检查电池是否完全插入笔记本电脑中。2.电池损坏,如果电池老化或发生机械故障、磨损和损伤,充电电流将会被阻塞从而无法进行充电,需要更换...
-
- 如何格式化手机(华为p50如何格式化手机)
-
步骤/方式1软件格式化:利用psiloc公司的软件sTools,进行格式化手机,锁码为12345步骤/方式2软格:在手机上输入*#7370#之后要求你输入锁码,初始密码是:12345步骤/方式3硬格:先关机,再开机的时候按住拨号键、“*...
-
2025-12-17 12:03 off999
- win10自动更新的禁用方法(win10自动更新的禁用方法是什么)
-
方法一:Windows设置 要想关闭Win10自动更新,比较简单的一种方法就是进入到Windows设置中,将Windows更新直接关闭。步骤如下: 1、按“Windows+I”键,打开Wind...
- 优化win7系统运行速度(优化win7系统运行速度多少)
-
优化WIN7系统开机启动项的操作方法1、在桌面上按组合键(win键+R)打开运行窗口,接着输入“regedit”,回车确认,2、打开注册表编辑器后,我们依次点击展开“HKEY_CURRENT_USE...
- win7设置每天自动开机时间(win7设置每天自动开机时间任务)
-
要在Windows7上设置每天自动开关机,您可以按照以下步骤操作:1.打开“控制面板”,单击“系统和安全”,然后选择“计划任务”。2.单击“创建基本任务”,输入一个适合您的任务名称,并添加相应的...
- 苹果电脑装双系统好用吗(苹果电脑安装双系统会不会对电脑不好)
-
好处:1、可以在保留原来的系统上再安装一个新系统,两个系统互不干扰,可以互相切换,使用方便。2、双系统可以在不用环境系进行软件调试没测试电脑的兼容性。3、双系统可以让用户体验不同的系统功能,提高用户的...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
