调优参数一:worker_processes
worker_processes表示worker线程的数量,每个worker进程都是单线程的进程,它们会调用各个模块以实现多种多样的功能。如果这些模块确认不会出现阻塞式的调用,那么,有多少CPU内核就应该配置多少个进程;反之,如果有可能出现阻塞式调用,那么需要配置稍多一些的worker进程。例如,如果业务方面会致使用户请求大量读取本地磁盘上的静态资源文件,而且服务器上的内存较小,以至于大部分的请求访问静态资源文件时都必须读取磁盘(磁头的寻址是缓慢的),而不是内存中的磁盘缓存,那么磁盘I/O调用可能会阻塞住worker进程少量时间,进而导致服务整体性能下降。
调优参数二:worker_connections
worker_connections表示每个worker 进程的最大连接数,默认1024个,通过使用worker_processes和worker_connections可以实际的设置nginx的总体最大连接数,比如worker_processes设置为2,worker_connections设置为1024,那么nginx的总体最大连接数就是2048个。但是这些连接数,不仅包含了nginx和客户端的链接,还包含了nginx和被代理的服务端的链接,因此不代表nginx的并发能力是2048,具体设置多少,要根据压测结果确定。不过实际情况中,nginx往往不会成为性能的瓶颈,瓶颈一般都在被代理的服务上(如tomcat)。
调优参数三:worker_cpu_affinity
worker_cpu_affin