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

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

相关推荐
西岭千秋雪_22 分钟前
Zookeeper监听机制
java·linux·服务器·spring·zookeeper
冬夜戏雪25 分钟前
[尚庭公寓P91-P104-及服务器服务的连接]
运维·服务器
inBuilder低代码平台1 小时前
Electron应用优化与性能调优策略
javascript·性能优化·electron
Jewel Q1 小时前
防火墙NAT策略处理流程
运维·服务器·网络
失重外太空啦1 小时前
NFS服务器的搭建
运维·服务器·网络
矮油0_o1 小时前
15.套接字和标准I/O
服务器·c语言·网络·网络编程·socket
利刃大大1 小时前
【高并发服务器】十二、LoopThreadPool线程池管理模块
服务器·c++·项目
埃伊蟹黄面2 小时前
告别手动编译:用Makefile自动化你的Linux项目
linux·服务器
Jonathan Star2 小时前
网站识别爬虫(包括以浏览器插件形式运行的爬虫)主要通过分析请求特征、行为模式等差异来区分人类用户和自动化程序
运维·爬虫·自动化
Once_day2 小时前
Linux错误(7)接口处于Down状态不通告IPv6地址变更事件
linux·运维·服务器