面试题整理2---Nginx 性能优化全方案

news2024/12/22 2:31:54

面试题整理2---Nginx 性能优化全方案

  • 1. 调整工作进程数和线程数
    • 1.1 调整工作进程数
    • 1.2 调整进程的最大连接数
  • 2. 配置Gzip压缩
    • 2.2 配置Gzip压缩
  • 3. 配置缓存策略
    • 3.1 配置浏览器缓存时间
    • 3.2 配置代理服务器缓存时间
  • 4. 优化文件访问方式
    • 4.1 使用sendfile()函数发送文件数据
    • 4.2 启用sendfile_max_chunk和tcp_nopush参数
  • 5. 优化日志配置
    • 5.1 调整日志级别
    • 5.2 配置日志切割和压缩
  • 6. 针对 Nginx 的系统内核参数调优
    • 6.1 增加内核参数调优内容
    • 6.2 文件句柄数量限制
  • 7. 其他优化建议
    • 7.1 使用CDN加速静态资源访问
    • 7.2 使用HTTP/2协议提高传输效率

Nginx是一款高性能的Web服务器,广泛应用于互联网领域。然而在高并发、大流量的情况下,Nginx的性能可能会受到一定的影响。因此,对Nginx进行性能优化是非常必要的。

1. 调整工作进程数和线程数

Nginx采用异步非阻塞的方式处理请求,这种方式可以充分利用CPU资源,提高并发处理能力。但是,过多的工作进程和线程会导致系统资源浪费,降低性能。因此,需要根据实际情况调整Nginx的工作进程数和线程数。

1.1 调整工作进程数

在描述调整工作进程数时,可以提到如何根据 CPU 核心数来调整。通常情况下,worker_processes 的设置推荐为 CPU 核心数,或者是根据机器的负载情况适当调整。

例如,常见的做法是设置为系统的 CPU 核心数:

worker_processes auto; # 自动根据 CPU 核心数调整

1.2 调整进程的最大连接数

worker_connections 是每个工作进程可以同时处理的连接数。如果服务器负载较高,可以适当增大这个值,典型值为 10242048

例如:

worker_connections 1024; # 每个进程的最大连接数

表示将每个工作进程的线程数设置为1024。

需要注意的是,线程数并不是越大越好,因为线程之间的竞争可能会导致性能下降。因此,需要根据实际情况进行调整。

2. 配置Gzip压缩

2.2 配置Gzip压缩

在Nginx配置文件中添加以下内容:

http {
    ...
    gzip on; # 开启Gzip压缩功能
    gzip_vary on;  # 启用gzip内容编码变化
    gzip_min_length 1k; # 设置最小压缩文件大小为1KB
    gzip_buffers 4 16k; # 设置压缩缓冲区个数和大小
    gzip_http_version 1.1; # 设置支持的HTTP协议版本为1.1
    gzip_comp_level 2; # 设置压缩级别为2(速度与压缩率的平衡)
    gzip_types text/plain application/x-javascript text/css application/xml application/javascript image/svg+xml; # 设置需要压缩的文件类型
    ...
}

3. 配置缓存策略

缓存是提高网站性能的重要手段之一。Nginx提供了多种缓存策略,可以根据实际需求进行配置。以下是一些常见的缓存策略:

3.1 配置浏览器缓存时间

配置浏览器缓存时间的示例没有问题。需要注意的是,对于不同类型的文件,可以设置不同的缓存时间。

例如,图片可以设置较长的缓存时间,而 HTML 文件则可以设置较短的缓存时间:

location ~* \.(jpg|jpeg|gif|png|svg)$ {
    add_header Cache-Control "public, max-age=31536000, immutable"; # 图片缓存1年,且不变动
}

location ~* \.(html|htm)$ {
    add_header Cache-Control "no-cache, must-revalidate"; # HTML文件不缓存
}

3.2 配置代理服务器缓存时间

对于代理缓存,您可以考虑增加一些更灵活的缓存策略,如缓存条件或不同状态码的缓存策略.

例如:

location / {
    proxy_pass http://backend; # 将请求转发到后端服务器
    proxy_cache mycache; # 启用缓存,命名为mycache
    proxy_cache_valid 200 302 10m;  # 正常和重定向响应缓存10分钟
	proxy_cache_valid 404 1m;       # 404错误响应缓存1分钟
	proxy_cache_valid 500 502 503 504 1m;  # 错误响应缓存1分钟
}

4. 优化文件访问方式

在处理静态文件时,Nginx默认会将文件读取到内存中进行处理。这种方式在大文件或高并发情况下会导致内存消耗过大,影响性能。因此,可以采用优化文件访问方式来提高性能。以下是一些优化方法:

4.1 使用sendfile()函数发送文件数据

sendfile_max_chunk 用于控制每次 sendfile() 发送的最大数据块大小,通常对于大文件下载,适当增大这个值可以提高性能。而 tcp_nopush 启用 TCP_CORK 功能,可以优化 TCP 数据包的发送,提高传输效率。

http {
    ...
    sendfile on; # 开启sendfile()函数支持功能(需要操作系统支持)
    ...
}

4.2 启用sendfile_max_chunk和tcp_nopush参数

通过设置sendfile_max_chunktcp_nopush参数,可以控制Nginx在发送文件时的最大分片大小和TCP_CORK选项。

例如:

http {
    ...
    sendfile_max_chunk 1m; # 设置最大分片大小为1MB
    tcp_nopush on; # 开启TCP_CORK选项
    ...
}

5. 优化日志配置

日志是排查问题的重要手段,但是过多的日志会导致磁盘空间不足,影响系统性能。因此,需要对Nginx的日志进行优化。以下是一些优化方法:

5.1 调整日志级别

Nginx支持多种日志级别,如debuginfonoticewarnerror等。可以通过修改Nginx配置文件中的log_level参数来调整日志级别。

例如:

http {
    ...
    error_log /var/log/nginx/error.log warn;  # 错误日志
    access_log /var/log/nginx/access.log combined;  # 访问日志
    ...
}

5.2 配置日志切割和压缩

日志切割和压缩的设置是正确的。如果日志文件过大,您还可以考虑使用日志轮转(logrotate)来定期压缩和删除旧的日志文件。

http {
    ...
    access_log /var/log/nginx/access.log combined buffer=32k flush=1m; # 配置访问日志切割和压缩功能
    error_log /var/log/nginx/error.log warn buffer=32k flush=1m; # 配置错误日志,并设置日志级别为warn
    ...
}

6. 针对 Nginx 的系统内核参数调优

6.1 增加内核参数调优内容

针对高并发场景,需对系统内核参数进行优化,主要包括文件句柄限制、TCP 参数调整等:

内核参数优化示例: 在 /etc/sysctl.conf 中增加以下内容:

# 增加文件句柄数量
fs.file-max = 2097152

# 调整网络参数以提高并发性能
net.core.somaxconn = 65535
net.core.netdev_max_backlog = 65535
net.ipv4.tcp_max_syn_backlog = 65535
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_fin_timeout = 15
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_max_tw_buckets = 5000
net.ipv4.tcp_keepalive_time = 300

生效命令:

sysctl -p

6.2 文件句柄数量限制

Nginx 需要足够的文件句柄来处理高并发连接,需调整 ulimit 参数:

/etc/security/limits.conf 中增加:

* soft nofile 65535
* hard nofile 65535

7. 其他优化建议

除了上述优化方法外,还有一些其他的优化建议:

7.1 使用CDN加速静态资源访问

CDN(Content Delivery Network)是一种内容分发网络

  • 可以将静态资源缓存到离用户更近的节点上,提高访问速度。
  • 可以使用阿里云、腾讯云等云服务商提供的CDN服务。

7.2 使用HTTP/2协议提高传输效率

HTTP/2协议是一种新的HTTP协议,支持多路复用、头部压缩等功能,可以提高传输效率。需要在Nginx和客户端同时支持HTTP/2协议才能生效。可以通过修改Nginx配置文件中的listen指令来启用HTTP/2协议。例如:

server {
    listen 443 ssl http2; # 启用HTTPS并启用HTTP/2协议支持功能(需要操作系统和SSL库支持)
    ...}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2263539.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C# opencvsharp 流程化-脚本化-(2)ROI

ROI ROI也是经常需要使用的方法。特别是在图像编辑中。ROI又称感兴趣的区域,但是图像是矩阵是矩形的,感兴趣的是乱八七糟的,所以还有一个Mask需要了解一下的。 public class RoiStep : IImageProcessingStep{public ImageProcessingStepType…

wazuh-modules-sca-scan

sca模块主函数wm_sca_main -> wm_sca_start 检查policy文件中的每一个项目wm_sca_check_policy static int wm_sca_check_policy(const cJSON * const policy, const cJSON * const checks, OSHash *global_check_list) {if(!policy) {return 1;}const cJSON * const id c…

uniapp 自定义图标03

插入工程,修改名称文件内容 编译运行

在Windows本地用网页查看编辑服务器上的 jupyter notebook

​ Motivation: jupyter notebook 可以存中间变量,方便我调整代码,但是怎么用服务器的GPU并在网页上查看编辑呢? 参考 https://zhuanlan.zhihu.com/p/440080687 服务端(Ubuntu): 激活环境 source activate my_env安装notebook …

【YOLO 项目实战】(11)YOLO8 数据集与模型训练

欢迎关注『youcans动手学模型』系列 本专栏内容和资源同步到 GitHub/youcans 【YOLO 项目实战】(1)YOLO5 环境配置与检测 【YOLO 项目实战】(10)YOLO8 环境配置与推理检测 【YOLO 项目实战】(11)YOLO8 数据…

Ubuntu22.04上安装esp-idf

一、安装准备# 建议使用Ubuntu 20.04 或 Ubuntu 22.04 操作系统 为了在 Ubuntu 22.04 中使用 esp-idf,需要安装一些依赖包 sudo apt-get install git wget flex bison gperf python3\python3-pip python3-venv cmake ninja-build ccache\libffi-dev libssl-dev dfu…

nginx-虚拟主机配置笔记

目录 nginx的安装可以查看nginx安装https://blog.csdn.net/m0_68472908/article/details/144609023?spm1001.2014.3001.5501 一、 基于域名 二、 基于IP 三、 基于端口 nginx的安装可以查看nginx安装https://blog.csdn.net/m0_68472908/article/details/144609023?spm100…

AlipayHK支付宝HK接入-商户收款(PHP)

一打开支付宝国际版 二、点开商户服务 三、下载源码

Soul Android端稳定性背后的那些事

前言:移动应用的稳定性对于用户体验和产品商业价值都有着至关重要的作用。应用崩溃会导致关键业务中断、用户留存率下降、品牌口碑变差、生命周期价值下降等影响,甚至会导致用户流失。因此,稳定性是APP质量构建体系中最基本和最关键的一环。当…

深度学习模型 DeepSeek-VL2 及其消费级显卡需求分析

DeepSeek-VL2 是由 DeepSeek 团队开发的一款先进的视觉语言模型,采用了混合专家(MoE)架构,旨在提升多模态理解能力。该模型包括三个版本:DeepSeek-VL2-Tiny、DeepSeek-VL2-Small 和 DeepSeek-VL2。每个版本具有不同的模…

首批|云轴科技ZStack成为开放智算产业联盟首批会员单位

近日 ,在Linux基金会AI & Data及中国开源软件推进联盟的指导之下,开放智算产业联盟成立大会在北京成功召开。在大会上,联盟首次公布了组织架构并颁发了首批会员单位证书。凭借ZStack AIOS平台智塔和在智算领域的技术创新,云轴…

word实现两栏格式公式居中,编号右对齐

1、确定分栏的宽度 选定一段文字 点击分栏:如本文的宽度为22.08字符 2、将公式设置为 两端对齐,首行无缩进。 将光标放在 公式前面 点击 格式-->段落-->制表位 在“制表位位置”输入-->11.04字符(22.08/211.04字符)&…

go语言zero框架中config读取不到.env文件问题排查与解决方案

在Go语言中,如果你使用.env文件来存储环境变量,通常会用到一些第三方库,例如github.com/joho/godotenv,它可以帮助我们从.env文件中读取环境变量。然而,在使用godotenv时,可能会遇到一些问题,导…

修改vscode设置的原理

转载请标明出处:小帆的帆的专栏 修改vscode设置 首先需要理解的是,vscode的系统设置和插件设置都是通过settings.json文件管理的。 vscode中有三个Settings,三个Settings分别对应三个settings.json文件 Default Settings:默认…

Qt之修改窗口标题、图标以及自定义标题栏(九)

Qt开发 系列文章 - titles-icons-titlebars(九) 目录 前言 一、修改标题 二、添加图标 三、更换标题栏 1.效果演示 2.创建标题栏类 3.定义相关函数 4.使用标题栏类 总结 前言 在我们利用Qt设计软件时,经常需要修改窗口标题、更改软…

环境变量的知识

目录 1. 环境变量的概念 2. 命令行参数 2.1 2.2 创建 code.c 文件 2.3 对比 ./code 执行和直接 code 执行 2.4 怎么可以不带 ./ 2.4.1 把我们的二进制文件拷贝到 usr/bin 路径下,也不用带 ./ 了 2.4.2 把我们自己的路径添加到环境变量里 3. 认识PATH 3.…

【时时三省】(C语言基础)通讯录1

山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 通讯录 1 .通讯录中能够存放1000个人的信息 每个人的信息: 名字年龄性别电话地址 2、增加人的信息 3、删除指定人的信息 4、修改指定人的信息 5,查找指定人的信…

Vulhub:Redis[漏洞复现]

4-unacc(Redis未授权代码执行) 启动漏洞环境 docker-compose up -d 阅读vulhub给出的漏洞文档 cat README.zh-cn.md # Redis 4.x/5.x 主从复制导致的命令执行 Redis是著名的开源Key-Value数据库,其具备在沙箱中执行Lua脚本的能力。 Redis未授权访问在4.x/5.0.5以…

【PGCCC】Postgresql Varlena 结构

前言 postgresql 会有一些变长的数据类型,存储都是采用 varlena 格式的(除了 cstring 类型),通过语句 SELECT typname FROM pg_type WHERE typlen -1就可以看到所有采用 varlena 格式的数据类型,比如常见的 text &am…

Ubuntu搭建ES8集群+加密通讯+https访问

目录 写在前面 一、前期准备 1. 创建用户和用户组 2. 修改limits.conf文件 3. 关闭操作系统swap功能 4. 调整mmap上限 二、安装ES 1.下载ES 2.配置集群间安全访问证书密钥 3.配置elasticsearch.yml 4.修改jvm.options 5.启动ES服务 6.修改密码 7.启用外部ht…