nginx的性能优化的概述

软件层面的提升硬件的使用率

增大CPU的利用率

增大内存的利用率

增大磁盘IO利用率

增大网络带宽利用率

提升硬件规格

网卡:万兆网卡、例如10G、25G、40G等

磁盘:固态硬盘,关注IOPS和BPS指标

CPU:更快的主频,更多的核心,更大缓存,更优的架构

内存:更快的访问速度

超出硬件上限后使用DNS

如何增大Nginx使用CPU的有效时长

能够使用全部CPU资源

master-worker进程架构

worker进程数量应当大于等于CPU核数

nginx进程之间不做无用功浪费CPU资源

worker进程不应该在繁忙时,主动退出CPU

worker进程间不应由争抢造成资源消耗

worker 进程数量应当等于CPU核数

worker进程不应调一些API导致主动让出CPU

拒绝类似的第三方模块

不被其他进程争抢资源

提升worker进程的优先级占用CPU更长时间

减少操作系统上耗资源的非nginx进程

设置worker进程数量的指令

Syntax: worker_processes number | auto;
Default: worker_processes 1; 指定worker进程数量
Context: main

为何一个CPU就可以同时运行多个进程

宏观上并行,微观上串行

把进程运行时间分为一段段的时间片

OS调度系统依次选择每个进程,最多执行时间片指定的时长

阻塞API引发的时间片内主动让出CPU

速度不一致引发的阻塞API

硬件执行速度不一致,例如CPU和磁盘

业务场景产生的阻塞API

例如同步读取网络报文

确保进程在运行态

R运行:正在运行或在运行队列中等待

S中断:休眠中,受阻,在等待某个条件的形成或接受到信号

D不可中断:收到信号不换醒和不可运行,进程必须等待直到有中断发生

Z僵死:进程已终止,但进程描述符存在,直到父进程调用wait4()系统调用后释放

T停止:进程收到SIGSTOP、SIGSTP、SIGTIN、SIGTOU 信号后停止

减少进程间的切换

nginx worker进程尽可能的处于R状态

R状态的进程数量大于CPU核心时,负载急速增高

[root@python ~]# uptime
10:51:14 up 17:22, 1 user, load average: 0.00, 0.01, 0.05 top
top - 10:50:43 up 17:22, 1 user, load average: 0.00, 0.01, 0.05
Tasks: 103 total, 1 running, 102 sleeping, 0 stopped, 0 zombie

尽可能减少进程间切换

何为进程间切换

是指CPU从一个进程或者线程切换到另一个进程或者线程

类别:主动切换 被动切换

Cost < 5us 进程切换代价,5微妙

减少主动切换

减少被动切换

增大进程优先级

绑定CPU

延迟处理新连接

使用TCP_DEFER_ACCEPT 延迟处理新连接

指令

listen address[:port] [deferred];
Default: listen *:80 | *:8000;
Context: server
Syntax:

  如何查看上下文切换次数vmstat

[root@python ~]# vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
r b swpd free buff cache si so bi bo in cs us sy id wa st
1 0 0 1229020 2108 481792 0 0 2 2 17 18 0 0 100 0 0

  dstat查看进程上下文切换

[root@python ~]# dstat
You did not select any stats, using -cdngy by default.
----total-cpu-usage---- -dsk/total- -net/total- ---paging-- ---system--
usr sys idl wai hiq siq| read writ| recv send| in out | int csw
0 0 100 0 0 0|4898B 5452B| 0 0 | 0 0 | 34 37
0 0 100 0 0 0| 0 12k| 60B 826B| 0 0 | 56 79
0 0 100 0 0 0| 0 0 | 60B 346B| 0 0 | 38 57
0 0 100 0 0 0| 0 0 | 60B 346B| 0 0 | 42 58
0 1 99 0 0 0| 0 0 | 60B 346B| 0 0 | 55 65
0 0 100 0 0 0| 0 0 | 60B 346B| 0 0 | 52 71
0 0 100 0 0 0| 0 4096B| 60B 346B| 0 0 | 42 61

  针对进程查看

[root@python ~]# pidstat  -w -p 30170 1
Linux 3.10.0-957.el7.x86_64 (python) 2019年07月19日 _x86_64_ (2 CPU)
主动切换 被动切换
11时33分15秒 UID PID cswch/s nvcswch/s Command
11时33分16秒 997 30170 0.00 0.00 nginx
11时33分17秒 997 30170 0.00 0.00 nginx
11时33分18秒 997 30170 0.00 0.00 nginx

  控制CPU时间的片大小

Nice 静态优先级-20-19 越小有优先级越高
Priority 动态优先级 0-139 #define DEFAULT_PRIO (MAX_RT_PRIO + NICE_WIDTH /2)
[root@python ~]# top
top - 11:49:18 up 18:20, 1 user, load average: 0.00, 0.01, 0.05
Tasks: 107 total, 1 running, 106 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.0 us, 5.6 sy, 0.0 ni, 94.4 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 1863252 total, 1198048 free, 174916 used, 490288 buff/cache
KiB Swap: 2097148 total, 2097148 free, 0 used. 1481828 avail Mem
动态 静态
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
30186 root 20 0 162020 2192 1548 R 5.6 0.1 0:00.03 top

  设置work进程静态优先级指令

Syntax: worker_priority number;
Default: worker_priority 0; 默认是零,设置优先级最高的话调到-20
Context: main

  worker进程间的负载均衡

如何打开此功能

listen指令后加reuseport

  CPU缓存命中率;worker进程绑定到CPU指令

Syntax: worker_cpu_affinity cpumask ...; worker_cpu_affinity auto [cpumask];
Default: —
Context: main

  

nginx 性能优化的概述及在CPU资源方面的处理的更多相关文章

  1. ab测试nginx Nginx性能优化

    转自:https://www.cnblogs.com/nulige/p/9369700.html 1.性能优化概述 在做性能优化前, 我们需要对如下进行考虑 1.当前系统结构瓶颈 观察指标 压力测试 ...

  2. 突破10万高并发的nginx性能优化经验(含内核参数优化)

    写的很好,推荐阅读. 转载:http://www.cnblogs.com/kevingrace/p/6094007.html 在日常的运维工作中,经常会用到nginx服务,也时常会碰到nginx因高并 ...

  3. 轻量级HTTP服务器Nginx(Nginx性能优化技巧)

    轻量级HTTP服务器Nginx(Nginx性能优化技巧)   文章来源于南非蚂蚁   一.编译安装过程优化 1.减小Nginx编译后的文件大小在编译Nginx时,默认以debug模式进行,而在debu ...

  4. Nginx性能优化参考

    nginx性能优化参考 1)调整配置文件中的配置项的值(配置文件:nginx.conf) worker_processes auto;开启的进程数,一般配置为跟逻辑CPU核数一样worker_rlim ...

  5. 关于nginx性能优化及基本概念

    参考文章: Nginx面试中最常见的18道题:http://blog.csdn.net/liyanlei5858/article/details/77924420 Nginx性能优化指南:http:/ ...

  6. Android应用性能优化系列视图篇——隐藏在资源图片中的内存杀手

    图片加载性能优化永远是Android领域中一个无法绕过的话题,经过数年的发展,涌现了很多成熟的图片加载开源库,比如Fresco.Picasso.UIL等等,使得图片加载不再是一个头疼的问题,并且大幅降 ...

  7. 第二十二章 Nginx性能优化

    一.性能优化概述 1.我们需要了解 1.首先需要了解我们当前系统的结构和瓶颈,了解当前使用的是什么,运行的是什么业务,都有哪些服务,了解每个服务最大能支撑多少并发.比如nginx作为静态资源服务并发是 ...

  8. Nginx 性能优化

    1.安全优化:隐藏Nginx版本号,server_tokens off; 2.安全优化:更改掉默认的用户  user nginx; 3.性能优化:  根据硬件配置,调整nginx worker 进程数 ...

  9. Nginx 性能优化有这篇就够了!

    目录: 1.Nginx运行工作进程数量 Nginx运行工作进程个数一般设置CPU的核心或者核心数x2.如果不了解cpu的核数,可以top命令之后按1看出来,也可以查看/proc/cpuinfo文件 g ...

随机推荐

  1. 「JSOI2015」isomorphism

    「JSOI2015」isomorphism 传送门 我们还是考虑树哈希来判同构. 但是我们需要使用一些特殊的手段来特殊对待假节点. 由于是无向树,我们首先求出重心,然后以重心为根跑树哈希. 此处我们不 ...

  2. JavaScript - 获取当前页面某个节点的个数

    document.getElementsByTagName(<tag_name>).length;

  3. Win10安装.Net Framework4.7及更高版本

    问题描述 使用VS打开项目工程时,提示未安装.net framework4.7,但在启用或关闭windows功能里已经勾选了.net framework 4.7的全部功能. 直接从网上下载.net f ...

  4. 日期格式在ios中的兼容性

    在IOS中支持 2017/3/2 这种格式的日期 不支持2017-3-2日期 /** * 返回兼容ios.android的日期时间格式 * @param dateTime String * @retu ...

  5. 单例模式的Java泛型实现方式

    import java.util.HashMap; import java.util.Map; /** * Created by zhao.wu on 2016/11/18. */ public cl ...

  6. JAVA基础学习(2)之判断

    2判断 2.1比较 2.1.1比较 System.out.println(amount>=10);输出的值为true或false 2.1.2关系运算 优先级 <算术运算 >赋值运算 ...

  7. CSS选择器效率问题

    今天学习了CSS各类选择器,对其效率问题有些疑问,故总结了一些学习笔记 有很多人都忘记了,或在简单的说没有意识到,CSS在我们手中,既能很高效,也可以变得很低能.这很容易被忘记,尤其是当你意识到你会的 ...

  8. mysql事务管理及spring声明式事务中主动异常抛出使数据库回滚

    mysql的引擎常用的有两个,一个MyISAM,另一个是InnoDB,mysql默认的为MyISAM,而InnoDB才是支持事务的.所以一般需要修改下,如何修改就不说了. 事务需要依赖数据库,好久没使 ...

  9. 【C语言】创建一个函数,判断某一正整数是否为水仙花数,并调用这个函数找出1000以内所有水仙花数

    #include <stdio.h> int fun(int x) { int a, b, c; a = x / ; b = x % / ; c = x % ; if (x == a * ...

  10. ASP.NET CORE 基础知识(一):概述【上】

    此为系列文章,对MSDN ASP.NET Core 的官方文档进行系统学习与翻译.其中或许会添加本人对 ASP.NET Core 的浅显理解 原文请参考MSDN ASP.NET Core. 这篇文章是 ...