Nginx 生产环境安全配置加固
以下是Nginx生产环境安全配置加固的综合方案,结合多个技术实践和行业标准整理:
一、基础安全防护
1. 隐藏版本信息
- 在
http或server块添加server_tokens off;,避免暴露Nginx版本号。 - 使用
headers-more-nginx-module模块彻底移除响应头中的Server: nginx标识。
2. 访问控制与权限限制
- 使用
allow/deny指令限制敏感接口的IP访问范围。 - 通过
worker_processes和worker_connections合理配置并发连接数。 - 以非root用户运行Nginx进程,并通过user指令指定低权限账户。
3. SSL/TLS加固
- 启用TLS 1.3协议,禁用SSLv2/SSLv3等不安全协议。
- 配置强加密套件,例如:
ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH;
ssl_prefer_server_ciphers on;
- 强制HTTP跳转HTTPS,并启用HSTS头部。
二、请求与资源防护
1. 请求限制与防DDoS
- 设置
limit_conn_zone限制单IP并发连接数,limit_req_zone限制请求速率。 - 配置超时参数:
client_body_timeout 10s;
client_header_timeout 10s;
keepalive_timeout 5s;
- 禁用
TRACE方法:limit_except GET POST { deny all; }。
- 目录与文件防护
- 禁用自动目录索引:
autoindex off;。 - 限制敏感文件访问:
location ~* \.(conf|log|bak)$ { deny all; }
三、高级安全策略
1. 安全头部增强
- 添加以下响应头防御XSS/点击劫持等攻击:
add_header X-Content-Type-Options "nosniff";
add_header X-Frame-Options "SAMEORIGIN";
add_header Content-Security-Policy "default-src 'self'";
- 使用X-XSS-Protection启用浏览器XSS过滤。
2. 模块与日志管理
- 禁用未使用的模块(如autoindex)减少攻击面。
- 启用访问日志和错误日志,配置log_format记录关键字段(如客户端IP、请求时间)。
四、运维规范
1. 配置与漏洞管理
- 使用nginx -t测试配置后通过nginx -s reload热加载。
- 定期通过nginx -V检查编译参数,确保未包含高危模块。
- 系统级防护
- 结合防火墙限制仅开放必要端口(如80/443)。
- 通过chmod设置配置文件权限(如nginx.conf设为640)。
以上配置需结合业务场景调整,建议使用nginx -t验证语法后分阶段实施。定期通过漏洞扫描工具(如CVE数据库)检查已知漏洞。
五、Nginx 生产环境标准配置方案
一、核心参数配置
1. 进程与连接控制
worker_processes auto; # 自动匹配CPU核心数 :ml-citation{ref="1,3" data="citationList"}
worker_cpu_affinity auto; # CPU亲和性优化(需Nginx 1.9+):ml-citation{ref="1,3" data="citationList"}
worker_rlimit_nofile 65535; # 进程最大文件句柄数 :ml-citation{ref="3,4" data="citationList"}
events { use epoll; # 高性能I/O模型(Linux环境):ml-citation{ref="1,3" data="citationList"} worker_connections 65535; # 单进程最大并发连接数 :ml-citation{ref="1,3" data="citationList"} multi_accept on; # 允许同时接受新连接 :ml-citation{ref="3,4" data="citationList"}
}
2. HTTP基础参数
http { client_max_body_size 20m; # 文件上传大小限制 :ml-citation{ref="4" data="citationList"} client_header_buffer_size 4k; # 请求头缓冲区 :ml-citation{ref="1,3" data="citationList"} keepalive_timeout 65s; # 长连接超时 :ml-citation{ref="2,4" data="citationList"} sendfile on; # 启用高效传输模式 :ml-citation{ref="3,4" data="citationList"} tcp_nopush on; # 减少网络报文数量 :ml-citation{ref="3,4" data="citationList"}
}
二、安全配置规范
1. 信息隐藏与访问控制
server_tokens off; # 隐藏Nginx版本号 :ml-citation{ref="1,2" data="citationList"}
add_header Server "Custom"; # 自定义Server头(需headers-more模块):ml-citation{ref="4,8" data="citationList"} location /nginx_status { allow 192.168.1.0/24; # 限制状态接口IP访问 :ml-citation{ref="5,6" data="citationList"} deny all;
}
2. SSL/TLS优化
ssl_protocols TLSv1.2 TLSv1.3; # 禁用旧协议 :ml-citation{ref="1,3" data="citationList"}
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256;
ssl_prefer_server_ciphers on; # 优先服务端加密套件 :ml-citation{ref="1,3" data="citationList"}
ssl_session_cache shared:SSL:10m; # 会话缓存复用 :ml-citation{ref="3,4" data="citationList"}
三、性能优化策略
1. 资源缓存与压缩
gzip on; # 启用GZIP压缩 :ml-citation{ref="2,4" data="citationList"}
gzip_min_length 1k; # 最小压缩文件大小 :ml-citation{ref="2,4" data="citationList"}
open_file_cache max=1000 inactive=20s; # 文件元数据缓存 :ml-citation{ref="3,4" data="citationList"} proxy_cache_path /data/cache levels=1:2 keys_zone=mycache:10m; # 反向代理缓存 :ml-citation{ref="4" data="citationList"}
2. 负载均衡配置
upstream backend { server 10.0.0.1:80 weight=5; # 权重分配 :ml-citation{ref="3,4" data="citationList"} server 10.0.0.2:80 backup; # 备用节点 :ml-citation{ref="3,4" data="citationList"} keepalive 32; # 长连接复用 :ml-citation{ref="4" data="citationList"} check interval=3000 rise=2 fall=3 timeout=1000; # 健康检查(需nginx_upstream_check模块):ml-citation{ref="6" data="citationList"}
}
四、运维管理标准
1. 日志与监控
log_format main '$remote_addr - $request_time - "$request" $status'; # 自定义日志格式 :ml-citation{ref="2,3" data="citationList"}
access_log /var/log/nginx/access.log main buffer=32k flush=5m; # 缓冲写入日志 :ml-citation{ref="4" data="citationList"}
error_log /var/log/nginx/error.log warn; # 错误日志级别控制 :ml-citation{ref="3,4" data="citationList"}
2. 系统级加固
- 配置文件权限:chmod 640 /etc/nginx/nginx.conf
- 以非特权用户运行:user www-data;
- 防火墙限制:仅开放80/443端口
实施说明
- 配置更新后必须执行 nginx -t 测试语法
- 推荐使用 logrotate 实现日志自动切割
- 生产环境建议采用 OpenResty 增强功能(如动态WAF)
七、配置样例:
标准配置
worker_processes auto;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;log_format main '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" ''"$http_user_agent" "$http_x_forwarded_for"';access_log /var/log/nginx/access.log main;error_log /var/log/nginx/error.log warn;sendfile on;tcp_nopush on;tcp_nodelay on;keepalive_timeout 65;types_hash_max_size 2048;server {listen 80;server_name localhost;location / {root /usr/share/nginx/html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location = /50x.html {root /usr/share/nginx/html;}}
}
生产环境优化建议:
- 增加并发连接数:根据实际负载调整worker_connections。例如,如果服务器有16核CPU,可以设置为16384或更高。
- 启用Gzip压缩:减少传输数据量,提高页面加载速度。
- 配置HTTPS:增强安全性,使用TLS协议。
- 使用高效的日志格式:例如,使用json格式的日志,便于后续分析。
- 配置缓存:使用Nginx的proxy_cache或fastcgi_cache来缓存静态文件和动态内容。
- 负载均衡:在多个服务器之间分发请求,使用Nginx的upstream模块。
- 安全性增强:配置HTTP头以增强安全性,例如X-Frame-Options、Content-Security-Policy等。
- 监控和告警:设置监控和告警机制,以便及时发现并解决问题。
- 性能调优:调整keepalive_timeout、client_max_body_size等参数以适应高并发场景。
- 使用高效的第三方模块:例如ngx_pagespeed、ngx_brotli等。
优化后的配置示例:
worker_processes auto; # 基于CPU核心数自动设置工作进程数,通常设置为CPU核心数或2倍CPU核心数。
pid /var/run/nginx.pid; # 设置nginx进程ID文件路径。
worker_rlimit_nofile 16384; # 设置单个工作进程可以打开的最大文件描述符数量。
events {worker_connections 16384; # 根据实际负载调整并发连接数。multi_accept on; # 允许每个工作进程同时接受多个新连接。
}
http {... # 其他配置保持不变。gzip on; # 启用Gzip压缩。gzip_types text/plain application/xml text/css application/javascript application/json application/x-javascript text/xml application/xml+rss text/javascript; # 设置需要压缩的MIME类型。... # 其他配置保持不变。server {listen 80 default_server; # 监听80端口,并设置为默认服务器。listen 443 ssl default_server; # 监听443端口,并启用SSL加密,设置为默认服务器。server_name localhost; # 根据实际域名设置。ssl_certificate /etc/ssl/certs/nginx-selfsigned.crt; # SSL证书路径。ssl_certificate_key /etc/ssl/private/nginx-selfsigned.key; # SSL私钥路径。ssl_session_cache shared:SSL:1m; # 设置SSL会话缓存。ssl_session_timeout 5m; # 设置SSL会话超时时间。... # 其他配置保持不变。location / { ... } # 其他location配置保持不变。... # 其他配置保持不变。}
相关文章:
Nginx 生产环境安全配置加固
以下是Nginx生产环境安全配置加固的综合方案,结合多个技术实践和行业标准整理: 一、基础安全防护 1. 隐藏版本信息 在http或server块添加server_tokens off;,避免暴露Nginx版本号。使用headers-more-nginx-module模块彻底移除响应头…...
C#中继承的核心定义
1. 继承的核心定义 继承 是面向对象编程(OOP)的核心特性之一,允许一个类(称为子类/派生类)基于另一个类(称为父类/基类)构建,自动获得父类的成员(字段、属…...
小白学Agent技术[5](Agent框架)
文章目录 Agent框架Single Agent框架BabyAGIAutoGPTHuggingGPTHuggingGPT工作原理说明GPT-EngineerAppAgentOS-Copilot Multi-Agent框架斯坦福虚拟小镇TaskWeaverMetaGPT微软UFOAgentScope现状 常见Agent项目比较概述技术规格和能力实际应用案例开发体验比较ChatChain模式 Agen…...
21.dirsearch:Web 路径扫描工具
一、项目介绍 dirsearch 是一款高效、多线程的 Web 路径扫描工具,专为渗透测试人员和网络安全研究人员设计,用于发现目标网站的隐藏目录、敏感文件及未授权接口。其支持自定义字典、代理配置、请求头伪装等功能,适用于红队渗透、漏洞挖掘及资…...
VSTO(C#)Excel开发4:打印设置
初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 源码指引:github源…...
设计模式Python版 模板方法模式(上)
文章目录 前言一、模板方法模式二、模板方法模式示例 前言 GOF设计模式分三大类: 创建型模式:关注对象的创建过程,包括单例模式、简单工厂模式、工厂方法模式、抽象工厂模式、原型模式和建造者模式。结构型模式:关注类和对象之间…...
源IP泄露后如何涅槃重生?高可用架构与自动化防御体系设计
一、架构层解决方案 1. 高防代理架构设计 推荐架构: 用户 → CDN(缓存静态资源) → 高防IP(流量清洗) → 源站集群(真实IP隐藏) ↑ Web应用防火墙(WAF) 实施要点&a…...
transformer bert 多头自注意力
输入的(a1,a2,a3,a4)是最终嵌入,是一个(512,768)的矩阵;而a1是一个token,尺寸是768 a1通过wq权重矩阵,经过全连接变换得到查询向量q1;a2通过Wk权重矩阵得到键向量k2;q和k点乘就是值…...
python-leetcode-定长子串中元音的最大数目
1456. 定长子串中元音的最大数目 - 力扣(LeetCode) 可以使用 滑动窗口 方法来解决这个问题。步骤如下: 初始化:计算前 k 个字符中元音字母的个数,作为初始窗口的值。滑动窗口:遍历字符串,每次右…...
Spring Boot + MyBatis-Plus 项目目录结构
以下是一个标准的 Spring Boot MyBatis-Plus 项目目录结构及文件命名规范,包含每个目录和文件的作用说明,适用于中大型项目开发: 项目根目录结构 src/ ├── main/ │ ├── java/ # Java 源代码 │ │ └── com/…...
Python之变量及简单的数据类型
本文来源于《Python从入门到实践》,自己整理以供工作参考 基本内容 print("Hello Python World!")message "Hello Python world!" print(message)message "Helllo Python Crash Course world!" print(message)name "ada lov…...
力扣 Hot 100 刷题记录 - 翻转二叉树
力扣 Hot 100 刷题记录 - 翻转二叉树 题目描述 翻转二叉树 是力扣 Hot 100 中的一道经典题目,题目要求如下: 给你一棵二叉树的根节点 root,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7…...
力扣215.数组中的第K个最大元素--堆排序法(java)
为了找到数组中第K个最大的元素,我们可以使用堆排序的方法。堆排序的核心是构建一个最大堆,并通过多次交换堆顶元素来找到前K个最大的元素。具体步骤如下: 方法思路 构建最大堆:将输入数组转换为最大堆,使得每个父节…...
MySQL增删改查操作 -- CRUD
个人主页:顾漂亮 目录 1.CRUD简介 2.Create新增 使用示例: 注意点: 3.Retrieve检索 使用示例: 注意点: 4.where条件查询 前置知识:-- 运算符 比较运算符 使用示例: 注意点…...
【算法day9】回文数-给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。
回文数 给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。 回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。 例如,121 是回文&#…...
RSA混合加密RSA混合加密
RSA混合加密是一种结合非对称加密(RSA)和对称加密(AES)的技术,通过两者的优势互补,实现高效且安全的数据传输。以下是详细解释和示例: RSA混合加密的核心原理 非对称加密(RSA&#x…...
蛋白质功能预测论文阅读记录2025(DPFunc、ProtCLIP)
前言 最近研究到瓶颈了,怎么优化都提升不了,遂开始看点最新的论文。 DPFunc 2025.1.2 Nature Communication 中南大学 论文地址:DPFunc: accurately predicting protein function via deep learning with domain-guided structure inform…...
Linux网络套接字编程——UDP服务器
Linux网络套接字编程——创建并绑定-CSDN博客 前面已经介绍了网络套接字的创建和绑定,这篇文章会通过UDP套接字实现一个UDP服务器。 先介绍将使用的接口。 recvfrom ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,struct sockaddr *src_addr,…...
主流向量数据库对比
在 AI 的 RAG(检索增强生成)研发领域,向量数据库是存储和查询向量嵌入的核心工具,用于支持高效的语义搜索和信息检索。向量嵌入是文本或其他非结构化数据的数值表示,RAG 系统通过这些嵌入从知识库中检索相关信息&#…...
54.HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧
温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦! HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧 文章目录 HarmonyOS NEXT 登录模块开发教程(…...
Vue3中 ref 与 reactive区别
ref 用途: ref 通常用于创建一个响应式的基本类型数据(如 string、number、boolean 等),但它也可以用于对象或数组 返回值: ref 返回一个带有 .value 属性的对象,访问或修改数据需要通过 .value 进行 使用场景: …...
结构型——装饰器模式
装饰器模式 装饰器是指能动态地为对象添加额外的功能的一种结构型设计模式。 特点 不修改原有代码的情况下,动态地扩展一个对象的功能。支持多个装饰器叠加使用透明性,装饰后的对象与原对象保持一致,客户端无需感知装饰过程 结构模式与实…...
在Simulink中将Excel数据导入可变负载模块的方法介绍
文章目录 数据准备与格式要求Excel数据格式MATLAB预处理数据导入方法使用From Spreadsheet模块(直接导入Excel)通过MATLAB工作区中转(From Workspace模块)使用1-D Lookup Table模块(非线性负载映射)Signal Builder模块(变载工况导入)可变负载模块配置注意事项与调试在S…...
分布式事务的产生背景及理论指导
分布式事务的产生背景 在现代互联网和企业级系统架构中,随着业务需求的增长,单体架构逐渐向微服务架构、分布式架构演进。传统单体架构下,事务管理相对简单,可以依赖数据库的本地事务(如 MySQL 的 ACID 事务ÿ…...
动手学强化学习-记录
3.5 蒙特卡洛方法 统计每一个状态s出现的总次数和总回报,用大数定律,总回报/总次数≈状态s的期望回报 第4章 动态规划算法 策略迭代中的策略评估使用贝尔曼期望方程来得到一个策略的状态价值函数,这是一个动 态规划的过程;而价值迭代直接使用贝尔曼最…...
RocketMQ性能优化篇
在分布式消息系统中,RocketMQ以其高性能、高可靠性和高可扩展性而被广泛应用。然而,为了充分发挥其性能优势,需要进行一系列的性能测试和优化。本文将从性能测试方法和优化实践两个方面,详细介绍如何对RocketMQ进行性能优化。通过…...
C语言为例谈数据依赖性
数据依赖性(Data Dependency)是指程序中后续操作的计算结果或内存访问依赖于前面操作的结果。在存在数据依赖的情况下,编译器或处理器会保证这些操作的执行顺序,因此不需要显式地使用内存屏障(Memory Barrierÿ…...
阿里云操作系统控制台评测:国产AI+运维 一站式运维管理平台
阿里云操作系统控制台评测:国产AI运维 一站式运维管理平台 引言 随着云计算技术的飞速发展,企业在云端的运维管理面临更高的要求。阿里云操作系统控制台作为一款集运维管理、智能助手和系统诊断等多功能于一体的工具,正逐步成为企业高效管理…...
C++中的const与类型转换艺术
目录 强制转换 static_cast const_cast reinterpret_cast dynamic_cast const关键字 修饰内置类型* 修饰指针类型* 类比 数组指针 指针数组 函数指针 指针函数 强制转换 C语言中的强制转换在C代码中依然可以使用,这种C风格的转换格式非常简单 TYPE a …...
网络安全演练有哪些形式
OPENVAS使用 1、确定指定IP是否能ping通 2、创建扫描目标 3、创建扫描任务(scan management →newtask) 4、开始任务start 5、查看扫描细节 6、查看扫描结果,包含漏洞详细信息,亦可到处PDF文件 7、导出扫描结果报告 8、为…...
