笔记定位:面向运维/开发人员的实战手册,聚焦高并发场景下Nginx调优、全链路监控、故障排查,覆盖配置优化、内核调优、监控工具、压测验证全流程
一、Nginx基础架构与性能瓶颈预判
1.1 核心工作模式
-
多进程+异步非阻塞:master进程管理配置/信号,worker进程处理请求,默认采用epoll事件驱动模型,支持海量并发连接
-
瓶颈常见点:文件句柄不足、worker进程数不合理、连接数超限、IO阻塞、内核参数限制、静态资源缓存失效、反向代理超时
1.2 优化核心原则
-
先监控定位瓶颈,再针对性调优,避免盲目改参数
-
分层优化:内核层 → Nginx配置层 → 业务层 → 缓存层
-
压测验证:每次调优后用压测工具验证性能提升效果
二.Nginx配置层性能优化(核心)
1.修改用户和组
编译nginx时指定用户和组
- 在./configure后面指定用户与组的参数
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx
修改nginx配置文件nginx.conf指定用户与组
在http{ }上
vim /usr/local/nginx/conf/nginx.conf
user nginx nginx; #修改用户为nginx,组为nginx
更改进程数与连接数
进程数
- 高并发环境下,需启动更多 Nginx 进程快速响应请求
- 用ps aux查看进程
- master process(主进程)开 1 个
- worker process(子进程)一般也开 1 个
- 可修改配置文件中 worker_processes 参数,通常设为 CPU 个数或其 2 倍,需先查看 CPU 核数
nproc-- 显示当前系统可用的 CPU 核心数量

进入nginx的主配置文件nginx.conf
vim /usr/local/nginx/conf/nginx.conf
在http{ }上
worker_processes 用于指定 Nginx 启动的工作进程数量
worker_processes 4;(用4个进程处理用户的请求) (与实际内核(cpu)要匹配)
重启服务
systemctl restart nginx
ps aux 查看进程数
ps -ef |grep nginx

为充分利用多核 CPU 性能,可给 Nginx 不同进程分配不同 CPU 核心,实现 CPU 性能最大化。

连接数
单个进程最大的并发连接数
vim /usr/local/nginx/conf/nginxconf

nginx总并发数:总并发数=worker_processes × worker_connections
静态缓存功能设置
- Nginx 可给静态资源设置缓存时间,相同内容后续请求直接返回,加快访问速度;
- 动态网
- 页不用设缓存时间。
设置静态资源缓存
- 进入主配置文件
vim /usr/local/nginx/conf/nginx.conf
location ~ \.(gif|jpg|png|bmp|ico)$ {
root html;
expires 1d;
}

nginx -t
systemctl restart nginx - 在cd/usr/local/nginx/html中添加图片
- 创建index.html
<html>
<body>
<h1>101</h1>
</body>
</html>
验证静态缓存
在浏览器中192.168.10.101/kgc.png

设置连接超时--keepalive_timeout
进入主配置文件
vim /usr/login/nginx/conf/nginx.conf
在http{ }下,server{ }上

日志切割
编写脚本
vim /opt/fenge.sh
#!/bin/bash
#Filename:fenge.sh
d=(date -d "-1 day" "+%Y%m%d")
logs_path="/var/log/nginx"
pid_path="/usr/local/nginx/logs/nginx.pid"
\[ -d logs_path ] || mkdir -p logs_path
mv /usr/local/nginx/logs/access.log {logs_path}/test.com-access.log-d
#移动并重命名日志文件
kill -USR1 (cat pid_path)
#重建新日志文件
find logs_path -mtime +30 |xargs rm -rf
#删除30天之前的日志文件未读

设置执行的权限
chmod +x /opt/fenge.sh
ls /var/log/nginx
ls /usr/local/nginx/logs/access.log
设置crontab任务,定期指向脚本进行日分割
crontab -e
30 1 * * * /opt/fenge.sh
每天凌晨1:30执行fengge.sh
配置网页压缩
- Nginx 的 ngx_http_gzip_module 模块可压缩文件,默认已安装,只需在配置文件中设置 gzip 开启、最小压缩字节数、缓存、HTTP 版本、压缩比、压缩类型、缓存服务器支持等参数,就能节约带宽、提升访问体验
修改主配置文件,加入压缩功能参数
vim /usr/local/nginx/conf/nginx.conf
在http中添加
gzip on;
gzip_buffers 4 64k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_min_length 1k;
gzip_vary on;
gzip_types text/plain text/javascript application/x-javascript text/css text/xml application/xml application/xml+rss;

在浏览器中 http://192.168.10.101/index.html

三.nginx的深度监控
解压数据包goaccess-1.7.2.tar.gz
核心监控指标
| 指标类型 | 核心指标 | 告警阈值 |
|---|---|---|
| 连接指标 | 活跃连接数、等待连接数、连接拒绝数 | 活跃连接数>80% worker_connections |
| 请求指标 | QPS、请求耗时、5xx/4xx错误率 | 5xx错误率>1%,平均耗时>500ms |
| 资源指标 | CPU使用率、内存占用、文件句柄数、磁盘IO | CPU>90%,内存>85%,句柄数接近上限 |
GoAccess安装
安装依赖
dnf install -y gcc make ncurses-devel openssl-devel gettext-devel
安装中文字体支持
dnf install -y wqy-microhei-fonts
解压
进入
配置
./configure -enable-utf8 --with-openssl
编译安装
localectl
配置中文环境
设置系统Locale为中文
(依赖包
dnf install -y glibc-langpack-zh
localectl set-locale LANG=zh_CN.UTF-8)
验证Locale是否生效
locale
GoAccess生成中文报告
goaccess --log-format=COMBINED --output=/usr/local/nginx/html/report.html --real-time-html /usr/local/nginx/logs/access.log
回车后不要动了
测试访问
去浏览器:192.168.10.101/report.html

四.nginx vts简介
.nginx vts安装
tar xzf nginx-1.26.3.tar.gz
unzip nginx-module-vts-master.zip
cd nginx-1.26.3
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_v2_module --with-http_realip_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcre --with-stream --add-module=/root/nginx-module-vts-master
make && make install
nginx配置开启vts
修改nginx配置文件
vim /usr/local/nginx/conf/nginx.conf


测试访问