news 2026/4/30 21:45:28

Nginx常用配置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Nginx常用配置

Nginx 常用配置围绕静态资源服务、反向代理、负载均衡、HTTPS 配置、限流等核心场景,以下是结构化的常用配置示例及关键说明。

一、 全局基础配置(nginx.conf 顶部)

控制 Nginx 进程的核心参数,影响整体性能。

# 工作进程数,建议等于 CPU 核心数 worker_processes 4; # 错误日志路径及级别(debug/info/warn/error/crit) error_log /var/log/nginx/error.log warn; # PID 文件路径 pid /var/run/nginx.pid; events { # 单个工作进程的最大连接数 worker_connections 1024; # 多路复用模型,Linux 推荐 epoll use epoll; }

二、 静态资源服务配置

用于部署前端静态文件(Vue/React 打包产物),优化访问性能。

http { include mime.types; default_type application/octet-stream; # 开启高效文件传输模式 sendfile on; # 长连接超时时间 keepalive_timeout 65; # 开启 gzip 压缩,减小传输体积 gzip on; gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; server { listen 80; server_name localhost; # 静态资源根目录 root /usr/share/nginx/html; index index.html index.htm; location / { # 解决前端路由刷新 404 问题(SPA 应用必备) try_files $uri $uri/ /index.html; } # 静态资源缓存策略,图片/JS/CSS 缓存 30 天 location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ { expires 30d; add_header Cache-Control "public, max-age=2592000"; } } }

三、 反向代理配置(代理 Java 后端服务)

将前端请求转发到后端 Spring Boot/Tomcat 服务,解决跨域和端口暴露问题。

http { server { listen 80; server_name api.example.com; location /api/ { # 后端服务地址 proxy_pass http://127.0.0.1:8080/; # 传递真实客户端 IP 给后端 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 反向代理超时时间 proxy_connect_timeout 60s; proxy_read_timeout 60s; } } }

四、 负载均衡配置

分发请求到多个后端实例,提升系统可用性和并发能力。

http { # 定义后端服务集群 upstream backend_cluster { # 策略1:轮询(默认) server 192.168.1.101:8080 weight=1; server 192.168.1.102:8080 weight=2; # weight 越大,权重越高 # 策略2:ip_hash(会话粘滞,同一IP固定到同一实例) # ip_hash; # 策略3:fair(按后端响应时间分配,需额外模块) # fair; } server { listen 80; server_name www.example.com; location / { proxy_pass http://backend_cluster; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } }

五、 HTTPS 配置(HTTP 转 HTTPS)

配置 SSL 证书,实现加密传输。

http { server { listen 80; server_name example.com; # HTTP 强制跳转 HTTPS return 301 https://$host$request_uri; } server { listen 443 ssl http2; server_name example.com; # SSL 证书路径 ssl_certificate /etc/nginx/ssl/example.crt; ssl_certificate_key /etc/nginx/ssl/example.key; # 安全的 SSL 协议版本 ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE; ssl_prefer_server_ciphers on; location / { root /usr/share/nginx/html; index index.html index.htm; } } }

六、 限流配置(防止恶意请求)

限制单位时间内的请求数,保护后端服务。

http { # 定义限流规则:基于 IP 限流,10r/s(每秒10个请求),缓冲区 20 个请求 limit_req_zone $binary_remote_addr zone=limit_zone:10m rate=10r/s; server { listen 80; server_name example.com; location / { # 应用限流规则,burst 突发请求数,nodelay 不延迟处理 limit_req zone=limit_zone burst=20 nodelay; proxy_pass http://backend_cluster; } } }

七、 关键配置检查与重载

# 检查配置语法是否正确 nginx -t # 平滑重载配置(不中断服务) nginx -s reload
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 12:47:21

期货与期权一体化平台可视化报告设计与应用

场外期权业务的复杂性要求报告具备直观、专业的可视化呈现能力。传统文字表格的报告形式难以有效传达收益分布、风险敞口等关键信息。本文将详细介绍期货与期权一体化平台中可视化报告的设计理念与实现方法,帮助企业提升期权业务沟通效率。 一、可视化报告的核心价…

作者头像 李华
网站建设 2026/4/24 10:10:07

期货与期权一体化平台合同关联配置指南

场外期权方案的执行需要与实际业务合同紧密关联,确保保值目标与业务需求一致。传统方式下期权方案与合同管理割裂,导致名义数量错配、期限不匹配等问题。本文将详细介绍期货与期权一体化平台中的合同关联配置功能,帮助企业建立规范化的期权业…

作者头像 李华
网站建设 2026/4/21 7:48:18

边缘AI爆发:芯片必须突破的5大核心要求

当AI从云端的“算力集群”走向终端的“万物智能”,边缘AI正在重塑我们与设备的交互方式——智能手表的健康监测、摄像头的实时安防、工业设备的预测性维护,这些场景的背后,都离不开边缘AI的支撑。与云端AI“不惜功耗堆算力”的逻辑不同&#…

作者头像 李华
网站建设 2026/4/20 1:26:43

【小程序毕设源码分享】基于springboot+uni-app的蛋糕订购小程序的设计与实现的设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华