nginx常用的性能优化

第一步调整工作进程数:

设置成auto,会自动按照CPU核心数来启动工作进程数,如果设置具体数字,则只会使用指定数量的CPU核心,无法将CPU同一时间都能用得到,所以就不能发挥服务器的最大的性能。

第二步增加进程连接数:

这一步可以为每个工作进程放大它能处理的连接数,也就是同一时间能够处理的最大连接数,这一步默认是1024,但是要调到多大需要根据业务情况来进行合理调节。

第三步开启高校传输模式:

sendfile on #当启用这个参数之后呢,nginx就会直接将文件从磁盘发送到socket缓冲区,而不是先将数据从内核缓冲区再拷贝到用户缓冲区然后再从用户缓冲区再拷贝到socket缓冲区,这样一来可以减少拷贝的次数,提高了传输效率,特别是处理大量这种静态文件(图片、css、JS文件)的时候效果更为显著。

tcp_nopush on #该参数用于在发送大块数据时优化 TCP 传输。启用此选项会在发送大量数据时,确保 TCP 不会在数据准备好之前就发送一部分,这有助于提高传输效率。

tcp_nodelay on #当启用这个参数的时候,该选项用于禁用 Nagle 算法。Nagle 算法的目的是减少小数据包的数量,通过将小的数据包合并成大数据包进行发送。然而,在某些性能要求较高的场景下(如实时应用),小延迟是可接受的,因而禁用此算法可以减少延迟,提高响应速度。

第四步复用链接:

由于http是一个无状态协议,客户端向服务端发送一个请求,服务端响应完之后就会断开这个请求,如果客户端需要发送多个请求,这样会导致服务器与客户端会产生大量的连接和断开的操作,从而会增加服务器的性能开销,通过设置 keepalive_timeout参数可以告知nginx处理完一个请求之后,先保持一下这个连接,以便来再次的接收客户端发送的后续的请求,降低因频繁建立和断开连接所带来的性能消耗。

第五步启用gzip压缩:

当启用gzip压缩之后,Nginx会先将指定的资源现在本地进行压缩一下,在响应给客户端,这样可以减少数据量,减少带宽的使用,但是会增加CPU的资源开销,因为会产生一个压缩的过程。

第六步设置浏览器缓存:

expires 30d; #这个参数用来告知浏览器缓存静态资源的过期时间,当浏览器访问这个网页之后,它会将一些图片之类的静态文件缓存到本地,下一次如果再有相同的请求资源,它就直接从这个本地的缓存中获取,就不会在向服务器请求了,可以大幅度减少服务器的带宽,但是如果某一些静态资源会频繁更新,就不要用这个参数了

第七启用代理缓存:

在 Nginx 中,代理缓存(Proxy Caching)是一种用于提高性能和减轻后端服务器负担的机制。通过缓存代理服务器从上游服务器获取的响应,Nginx 可以在后续请求中直接提供缓存的内容,而无需每次都请求后端服务器。这可以显著提高响应速度和处理能力。

具体配置:nginx代理缓存_nginx 代理缓存-CSDN博客

注意:不管是性能优化也好,环境配置也罢,都需要结合具体的业务场景下进行,没有固定不变的配置参数。

相关推荐
igcllq1 小时前
ubuntu 安装kvm 创建windos虚拟机
linux·运维·服务器·ubuntu·虚拟机·kvm
hrlees1 小时前
从零开始Ubuntu24.04上Docker构建自动化部署(三)Docker安装Nginx
nginx·docker·自动化
威迪斯特2 小时前
linux网络服务:网络名称解析管理器,提供系统级的DNS缓存服务,并管理网络连接和DNS解析的服务systemd-resolved详解
linux·服务器·网络·缓存·dns·域名解析
dntktop2 小时前
3D建模软件 | Blender v4.2.2 绿色版
运维
余识-2 小时前
docker零基础入门教程
运维·docker·容器
雅欣-鱼子酱2 小时前
什么是PD协议?握手过程是怎样的?
linux·运维·网络
小安运维日记3 小时前
Linux云计算 |【第四阶段】RDBMS1-DAY5
linux·运维·服务器·数据库·mysql·云计算
@游子3 小时前
Linux-基础篇文件权限和组的管理-练习实践(附答案)
linux·运维·服务器
西西o3 小时前
Linux服务安装node,npm与yarn
linux·运维·npm