Nginx 高并发连接

  • 什么是IO,输入输出

    
  • Web服务器IO的整个详细过程

 
 
        (1)客户发起请求到服务器网卡;
        (2)服务器网卡接受到请求后转交给内核处理;
        (3)内核根据请求对应的套接字,将请求交给工作在用户空间的Web服务器进程
        (4)Web服务器进程根据用户请求,向内核进行系统调用,申请获取相应资源(如index.html)
        (5)内核发现web服务器进程请求的是一个存放在硬盘上的资源,因此通过驱动程序连接磁盘
        (6)内核调度磁盘,获取需要的资源
        (7)内核将资源存放在自己的缓冲区中,并通知Web服务器进程
        (8)Web服务器进程通过系统调用取得资源,并将其复制到进程自己的缓冲区中
        (9)Web服务器进程形成响应,通过系统调用再次发给内核以响应用户请求
        (10)内核将响应发送至网卡
       (11)网卡发送响应给用户
        用户请求-->送达到用户空间-->系统调用-->内核空间-->内核到磁盘上读取网页资源->返回到用户空间->响应给用户。
        客户端向Web服务器请求的过程中,有两个I/O过程,一个就是客户端请求的I/O,另一个就是Web服务器请求页面的磁盘I/O
 
 
  • IO介绍:

          网络IO
          磁盘IO
  • IO模型:

       同步/异步        关注的是(被调用者)消息通知机制
            同步,            调用者自己主动等待被调用者返回消息,才能继续执行
            异步,            被调用者通过状态,通知或回调机制主动通知调用者被调用者的运行状态
        阻塞/非阻塞      关注的是调用者在等待结果返回之前的状态
            阻塞:              调用结果返回之前,调用者被挂起
            非阻塞:          调用者不会被挂起
     
  • 下面我们来举例说明

      老王的视频是洗衣服,我们不洗衣服,我们喝茶,万丈红尘三杯酒,千秋大业一壶茶,男人都是干大事的,所以我们喝茶。
      老张爱喝茶,废话不说,煮开水。
      出场人物:老张,水壶两把(普通水壶,简称水壶;会响的水壶,简称响水壶)。
  1. 老张把水壶放到火上,立等水开。(同步阻塞)老张觉得自己有点傻
  2. 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞)老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
  3. 老张把响水壶放到火上,立等水开。(异步阻塞)老张觉得这样傻等意义不大
  4. 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞)老张觉得自己聪明了。
 
  • IO复用:

        老张开了一家茶叶公司,不时有客户要来品茶,老张自己忙不过来,就找了20个秘书,一个秘书可以同时泡一种茶,但是不用亲自泡茶了,但是老周需要过一会(阻塞在这)问一下20个秘书,
信号驱动:
        老张开了一家茶叶公司,不时有客户要来品茶,老张自己忙不过来,就找了20个秘书,一个秘书可以同时泡一种茶,但是不用亲自泡茶了,老周给一个秘书一个信号,如果泡好了就给老周发个信息,老周就知道了
 
        所谓同步异步,只是对于水壶而言。普通水壶,同步;响水壶,异步。虽然都能干活,但响水壶可以在自己完工之后,提示老张水开了。这是普通水壶所不能及的。同步只能让调用者去轮询自己(情况2中),造成老张效率的低下。
 
        所谓阻塞非阻塞,仅仅对于老张而言。立等的老张,阻塞;看电视的老张,非阻塞。情况1和情况3中老张就是阻塞的,媳妇喊他都不知道。虽然3中响水壶是异步的,可对于立等的老张没有太大的意义。所以一般异步是配合非阻塞使用的,这样才能发挥异步的效用。
 
        另外我们可以从另一个角度来看看这个同步和异步,如果采用同步,老张最累,如果采用异步,响水壶最累,在系统中分别对应着应用程序和内核,那为什么我们要让程序省事,让内核累死呢?
 
 
 
IO模型的具体实现:

  • Select:    Linux实现对应,I/O复用模型,BSD4.2最早实现
  •     监听端口数量受限于 /proc/sys/fs/file-max   
        对socket扫描是轮询
        数组   1024
  • Poll:Linux实现,对应I/O复用模型,System V unix最早实现
          本质和select没有区别,只是将数据放置内核空间
            最大连接数没有限制
            水平触发   如果报告了该状态,没有被处理,下次poll时会再次报告该状态
  • Epoll:Linux实现,对应I/O复用模型,具有信号驱动I/O模型的某些特性
           select 和poll 的增强版本,支持水平触发和边缘触发  某些事件只通知一次
            “事件”的就绪通知机制,callback,。而select采用的是轮询
             没有最大连接数限制 ,1G内存支持监听10w个端口
             效率提升  非轮询
  • Kqueue:FreeBSD实现,对应I/O复用模型,具有信号驱动 I/O模型的某些特性
  • /dev/poll:SUN的Solaris实现,对应I/O复用模型,具有信号 驱动I/O模型的某些特性Iocp:   Windows实现,异步I/O模型 
进程和线程

  • 进程是具有一定独立功能的,在计算机中已经运行的程序的实体
                在linux 2.4之前,进程是基本运作单位,
                在支持线程的系统中,linux2.6之后,线程才是基本的运作单位
  • 现在计算机系统可在同一段时间内以进程的形式将多个程序加载到存储器中,并借由时间共享(或称时分复用),以在一个处理器上表现出同时(平行性)运行的感觉
 
  • 同样的,使用多线程技术(多线程即每一个线程都代表进程内的一个独立执行上下文)的操作系统或计算机架构,同样程序的平行线程,可以在多cpu主机或网络上真正同时运行(在不同cpu上)
 
 
三种工作模型比较:
        Web服务器要为用户提供服务,必须以某种方式,工作在某个套接字上。一般Web服务器在处理用户请求时,一般有如下三种方式可选择:多进程方式、多线程方式、异步方式。
            多进程方式:为每个请求启动一个进程来处理。由于在操作系统中,生成进程、销毁进程、进程间切换都很消耗CPU和内存,当负载高时,性能会明显降低。
                优点:稳定性!由于采用独立进程处理独立请求,而进程之间是独立的,单个进程问题不会影响其他进程,因此稳定性最好。
                缺点: 资源占用!当请求过大时,需要大量的进程处理请求,进程生成、切换开销很大,而且进程间资源是独立的,造成内存重复利用。
            多线程方式:一个进程中用多个线程处理用户请求。由于线程开销明显小于进程,而且部分资源还可以共享,因此效率较高。
                优点:开销较小!线程间部分数据是共享的,且线程生成与线程间的切换所需资源开销比进程间切换小得多。
                缺点:稳定性!线程切换过快可能造成线程抖动,且线程过多会造成服务器不稳定。
            异步方式:使用非阻塞方式处理请求,是三种方式中开销最小的。但异步方式虽然效率高,但要求也高,因为多任务之间的调度如果出现问题,就可能出现整体故障,
            因此使用异步工作的,一般是一些功能相对简单,但却符合服务器任务调度、且代码中没有影响调度的错误代码存在的程序。
                优点:性能最好!一个进程或线程处理多个请求,不需要额外开销,性能最好,资源占用最低。
                缺点:稳定性!某个进程或线程出错,可能导致大量请求无法处理,甚至导致整个服务宕机          

10.6 Nginx 高并发连接的更多相关文章

  1. tengine编译安装及nginx高并发内核参数优化

    Tengine Tengine介绍 Tengine是由淘宝网发起的Web服务器项目.它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性. Tengine的性能和稳定性已经在大型的 ...

  2. SpringCloud、Nginx高并发核心编程 【2020年11月新书 】

    文章太长,建议收藏起来,慢慢读! 疯狂创客圈为小伙伴奉上以下珍贵的学习资源: 疯狂创客圈 经典极品 : 三大本< Java 高并发 三部曲 > 面试 + 大厂 + 涨薪必备 疯狂创客圈 经 ...

  3. Nginx 限制并发连接和并发请求数配置

    Nginx限制并发连接和并发请求数配置   by:授客  QQ:1033553122   测试环境 nginx-1.10.0 配置介绍 查看是否内置模块 # pwd /mnt/nginx-1.10.0 ...

  4. [效果不错] nginx 高并发参数配置及linux内核参数优化,完整的内核优化设置。PHP-FPM高负载解决办法。

    背景:对vps小资源的实践中对,https://justwinit.cn/post/7536/ 的再优化,再实践,再优化,特别是Nginx,PHP,内核: 零)Nginx: error_log /da ...

  5. nginx 高并发配置参数(转载)

    声明:原文章来自http://blog.csdn.net/oonets334/article/details/7528558.如需知道更详细内容请访问. 一.一般来说nginx 配置文件中对优化比较有 ...

  6. nginx高并发优化

    一、一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1.  worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu ...

  7. Nginx高并发优化方案

    原网址: https://blog.csdn.net/HoeWang/article/details/81221463 一.一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1. work ...

  8. NGINX高并发配置

    1.  worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu计为8). 2.  worker_cpu_affinity 000 ...

  9. nginx 高并发配置参数

    一.一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1.  worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu ...

随机推荐

  1. 刷题-力扣-剑指 Offer II 055. 二叉搜索树迭代器

    剑指 Offer II 055. 二叉搜索树迭代器 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/kTOapQ 著作权归领扣网络所有 ...

  2. 读vue-cli3 官方文档的一些学习记录

    原来一直以为vue@cli3 就是创建模板的工具,读了官方文档才知道原来这么有用,不少配置让我长见识了 Prefetch 懒加载配置 懒加载相信大家都是知道的,使用Import() 语法就可以在需要的 ...

  3. js获取文件名和后缀名

  4. 在Excel中怎样才能在某一行前面一次插入多行?

    你在要插入的行以下选中多少行,点插入,就能插入多少行. ​

  5. cmd(命令行)超好用的技巧,很不错的打开方式

    超快速打开管理cmd widows + x 按a 直接打开文件位置,在地址栏输入cmd 地址----直接cmd打开到所在文件位置 ex:cmd D:\work cd ../../../ 返回上几层的方 ...

  6. 前后端数据交互(六)——ajax 、fetch 和 axios 优缺点及比较

    一.ajax.fetch 和 axios 简介 1.1.ajax ajax是最早出现发送后端请求的技术,属于原生 js .ajax使用源码,请点击<原生 ajax 请求详解>查看.一般使用 ...

  7. Python常见问题 - 写入数据到 excel 报 ValueError: invalid literal for int() with base 10 错误

    背景 在上写入数据到excel中,报了以下错误 出现原因 对于写入excel场景下出现该错误的话,很大概率是写入数据的单元格原本的数据格式有问题 解决方法 清理掉单元格的旧数据,然后再写入就可以了

  8. 为老的vueCli项目添加vite支持

    1.前言 接手公司的某个项目已经两年了,现在每次启动项目都接近1分钟,hmr也要好几秒的时间,but vite2发布之后就看到了曙光,但是一直没有动手进行升级,昨天终于忍不住了,升级之后几秒钟就完成了 ...

  9. 学习PHP中统计扩展函数的使用

    做统计相关系统的朋友一定都会学习过什么正态分布.方差.标准差之类的概念,在 PHP 中,也有相应的扩展函数是专门为这些统计相关的功能所开发的.我们今天要学习的 stats 扩展函数库就是这类操作函数. ...

  10. mysql将数据导入到另外一张操作

    insert into ydcq_member_class (ClassId,signcount,UserId) select 64,2,`员工编号` from `学员名单`