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博客

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

相关推荐
Linux运维技术栈5 分钟前
Ansible(自动化运维)环境搭建及ansible-vault加密配置
运维·自动化·ansible
Bessssss1 小时前
centos权限大集合,覆盖多种权限类型,解惑权限后有“. + t s”问题!
linux·运维·centos
苹果醋31 小时前
Golang的文件加密工具
运维·vue.js·spring boot·nginx·课程设计
jwensh2 小时前
【Jenkins】Declarative和Scripted两种脚本模式有什么具体的区别
运维·前端·jenkins
大熊程序猿3 小时前
xxl-job docker 安装
运维·docker·容器
董健正3 小时前
centos制作离线安装包
linux·运维·centos
shelby_loo3 小时前
使用 Docker 在 Ubuntu 下部署 Cloudflared Tunnel 服务器
服务器·ubuntu·docker
咏颜4 小时前
Ubuntu离线安装Docker容器
linux·运维·服务器·经验分享·ubuntu·docker
DexterLien5 小时前
Debian 12 安装配置 fail2ban 保护 SSH 访问
运维·debian·ssh·fail2ban
爱学习的白杨树5 小时前
什么是MVCC?
java·服务器·数据库