news 2026/5/2 21:36:49

一款好用的 Nginx 日志分析工具

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一款好用的 Nginx 日志分析工具

轻量级的 Nginx 日志分析面板。

实时看 PV/UV 数据
IP 归属地查询(国内用 ip2region 本地库,国外走 ip-api)
客户端/浏览器解析
支持多站点
支持自定义日志格式
后端是 Go + Gin,前端是 Vue3 + Vite + PrimeVue,数据库就一个 SQLite,够轻量。
docker 运行:

dockerrun -d --name nginxpulse\-p8088:8088\-p8089:8089\-eWEBSITES='[{"name":"主站","logPath":"/share/log/nginx/access.log","domains":["example.com"]}]'\-v /your/nginx/logs/access.log:/share/log/nginx/access.log:ro\-v$(pwd)/var/nginxpulse_data:/app/var/nginxpulse_data\magiccoders/nginxpulse:latest

把 /your/nginx/logs/access.log 换成你自己的日志路径就行。

Docker Compose
如果喜欢 compose,也行:

version:"3.8"services: nginxpulse: image:magiccoders/nginxpulse:latest container_name:nginxpulse ports: -"8088:8088"-"8089:8089"environment: WEBSITES:'[{"name":"主站","logPath":"/share/log/nginx/access.log","domains":["example.com"]}]'volumes: -./nginx_logs/access.log:/share/log/nginx/access.log:ro -./var/nginxpulse_data:/app/var/nginxpulse_data restart:unless-stopped

跑起来之后:

前端面板:http://localhost:8088
后端 API:http://localhost:8089

多网站怎么配?
如果你有多个站点,WEBSITES 传数组就行:

WEBSITES='[ {"name":"主站","logPath":"/logs/main.log","domains":["www.example.com"]}, {"name":"博客","logPath":"/logs/blog.log","domains":["blog.example.com"]} ]'

日志按天切割的话,支持通配符:

{"logPath":"/logs/access-*.log"}

.gz 压缩日志也能直接解析,不用手动解压。

几个实用功能

  1. 远端日志拉取
    日志不在本机?没关系,支持 SFTP、HTTP、S3/OSS 三种方式拉取远端日志。

比如 SFTP:

{"id":"sftp-main","type":"sftp","host":"1.2.3.4","port":22,"user":"nginx","auth":{"keyFile":"/secrets/id_rsa"},"path":"/var/log/nginx/access.log"}
  1. Push Agent
    如果服务器在内网或者边缘节点,可以用 Agent 主动推送日志。在日志服务器上跑一个轻量 agent,实时把日志推到 NginxPulse 主服务。

  2. 自定义日志格式
    不是默认的 combined 格式?可以自定义。支持两种方式:

方式一:直接写 log_format 语法

{"logFormat":"$remote_addr-$remote_user[$time_local]\"$request\"$status$body_bytes_sent"}

方式二:正则(命名分组)

{"logRegex":"^(?P<ip>\\S+) - (?P<user>\\S+)\\[(?P<time>[^\\]]+)\\]..."}
  1. Caddy 也支持
    用 Caddy 的朋友也能用,配置 logType: “caddy” 就行,会按 JSON 格式解析。

  2. 访问控制
    生产环境可以加个密钥:

ACCESS_KEYS='["your-secret-key"]'

访问时需要带上 X-NginxPulse-Key 请求头,前端会自动弹窗让你输入。

常见问题
Q:跑起来后日志明细是空的?

A:多半是权限问题。给日志目录和数据目录加个权限:

chmod-R777/path/to/logs /path/to/nginxpulse_data

Q:有访问但是 PV/UV 都是 0?

A:默认排除内网 IP。如果想统计内网流量,把 PV_EXCLUDE_IPS 设成空数组:

PV_EXCLUDE_IPS='[]'

单体部署
如果不想用 Docker,可以构建成单个可执行文件:

./scripts/build_single.sh

会生成一个内置前端的二进制文件,直接运行就能同时提供前后端服务。支持 amd64 和 arm64。

最后
GitHub 地址:

https://github.com/likaia/nginxpulse

在线演示:

https://nginx-pulse.kaisir.cn/
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 15:33:46

让本地知识引导AI追踪社区变迁,让AI真正理解社会现象

最近有一项研究让我十分好奇&#xff0c;它似乎在尝试翻转我们熟悉的剧本——不是用人工智能去“分析”社区&#xff0c;而是让社区来“教会”人工智能如何看世界。这听起来像是一种充满温度的技术民主化实验。通常&#xff0c;当我们谈论机器学习与城市变迁&#xff0c;总不免…

作者头像 李华
网站建设 2026/4/23 9:15:03

百科——光伏气象站

问&#xff1a;光伏项目气象站的核心定位是什么&#xff1f;为什么说它是电站运维的“智慧之眼”&#xff1f; 答&#xff1a;核心定位是光伏电站专属气象监测终端&#xff0c;主打“精准监测、稳定运行、无人值守”&#xff0c;之所以被称为电站运维的“智慧之眼”&#xff0…

作者头像 李华
网站建设 2026/5/1 20:38:14

单片机嵌入式试题(第31期)你对它如何理解?我帮你打通三维数组的“经脉“(理解)!其实多层结构体差不多,只是元素的数据类型不一样,举例多层结构体说明。

多层结构体和三维数组有相似之处&#xff0c;只是每个维度的数据类型可以不同。让我用多层结构体来类比&#xff1a; 1. 基础对比&#xff1a;数组 vs 结构体 // 三维数组&#xff1a;所有元素类型相同 int arr[2][3][4]; // 全是int类型// 多层结构体&#xff1a;每层可以不…

作者头像 李华
网站建设 2026/4/28 7:39:38

前端HTML转PDF的两种主流方案深度解析

前端 HTML 转 PDF 的两种主流方案深度解析&#xff08;2026 年版&#xff09; 目前前端生成 PDF 最主流的两种方案是&#xff1a; 客户端方案&#xff1a;html2canvas jsPDF&#xff08;或其封装库 html2pdf.js&#xff09;服务端方案&#xff1a;Puppeteer / Playwright&am…

作者头像 李华
网站建设 2026/5/1 9:20:47

HoRain云--FreeSWITCH容器化全流程指南

&#x1f3ac; HoRain云小助手&#xff1a;个人主页 &#x1f525; 个人专栏: 《Linux 系列教程》《c语言教程》 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;…

作者头像 李华