玩转Nginx之一:基础概念

Nginx

web服务器:http协议

http协议:html,MIME(多用途互联网邮件拓展)

major/minor

text/html,text/plain,image/jpeg

web资源:URL(scheme://server:port/path/to/source)

方法:GET,HEAD(相应首部)读取资源

POST提交表单

PUT上传数据

DELETE删除数据

WEBDAV: 开发处理数据传输

http事务:request<—>responce

request:<method><URL><version>

          <HEADERS>

          …

          <body>

responce:<version><status><reason phrase>

<HEADERS>

<body>

status:

            1xx:信息类

            2xx:成功类

            3xx:重定向(301,302)

            4xx:错误类(客户端错误)

            5xx:错误类(服务器端错误)

认证:basic:明文认证

digest:表单认证,密文

httpd:MPM(用来定义并发响应模型)

prefok(select模式只支持1014路的并发):进程按照自己的状态创建子进程,子进程响应用户请求

worker:cow(写时复制模型),线程响应请求,模拟一个线程响应多个请求(进程创建的线程数是有限的,性能够比较差)

event:真正意义上的事件驱动,实现一个进程响应多个请求

I/O模型:

进程间通信:关注的是消息通知的机制

同步:synchronous 一个任务的完成需要依赖的话要保证依赖的完成才能执行被依赖的任务。两个任务的状态保持一致

异步:asynchronous不需要等待被依赖的任务完成,只是通知被依赖的任务完成了什么工作即可。依赖于回调函数等,

消息通知:

        同步:等待对方返回消息

        异步:被调用者不能立即返回消息给调用者,通过消息(状态),通知,回调通知调用者

        状态:调用者每隔一段时间就要检查一次;轮询,效率很低

        通知:效率较高;

        回调:和通知方式类似

阻塞/非阻塞:在同步过程中,关注调用者等待调用结果返回之前所处的状态

阻塞(block):调用结果返回之前,调用者会被挂起(和同步是有区别的)

非阻塞(nonblock):和阻塞相反,调用结果返回之前,调用者不会被挂起,明显提高CPU利用率,不理之处在于导致cpu上下文切换之间的负载

常用的io模型:

同步阻塞:同步模型的调用者在被调用者访问之前是被挂起的,效率最低

同步非阻塞:同步模型的调用者在等待被调用者的过程中还能执行其他,性能同样比较低,第一阶段盲等,第二阶段仍然是挂起

io multipexing:io复用,同步阻塞的另外一种方式,select,poll。不是内核级别的调用了

signal driven io:信号量驱动io也可以叫做异步阻塞IO;event;一个进程响应多个请求(第一阶段不会被阻塞)

asynchronous io:异步非阻塞io;第一阶段和第二阶段都不会被阻塞

异步阻塞:等待消息通知时被阻塞,

常见的io方式:网络io:本质是socket文件的读取

    磁盘io:数据流的读取

    每次io都会经由两个阶段:

      本地读取为例:(1)数据加载到内核的内存中(内核缓冲区)

      (2)从内核内存空间复制到用户空间的进程内存空间中

总结:等待数据准备完成也就是上述(1)

数据从内核复制到进程的阶段就是上述(2)

       同步阻塞    同步非阻塞     io复用            信号驱动机制         异步io

blob.png

玩转Nginx之一:基础概念

原创文章,作者:wanghui,如若转载,请注明出处:http://www.178linux.com/53983

(0)
wanghuiwanghui
上一篇 2016-10-29 21:24
下一篇 2016-10-29 21:25

相关推荐

  • 最近了解到的命令

    ssh:secure  shell shell  人机交互的语言查询当前系统使用了哪个shell(接口程序) echo $SHELL 查询当前系统已安装的所有shell cat /etc/shells Shell提示符 whoami 显示当前的登录用户名 hostname 显示当前的主机名      pwd …

    Linux干货 2017-07-13
  • 计算机组成及Linux基础

    第1题:描述计算机的组成及功能 1.1计算机的组成       计算机是有 运算器,控制器,存储器,输入设备和输出设备组成计算机 1.2计算机各部件功能 运算器 对数据进行算术运算,逻辑运算和对数据进行加工处理 存储器 存储程序,数据和各种信号,命令等信息,并在需要时提供这些信息 控制器 是整个计算机的中枢神…

    Linux干货 2017-07-02
  • Centos7 编译安装 zabbix3.0

    服务安装配置: 系统版本:CentOS Linux release 7.2.1511 (Core)   zabbix 安装 关闭firewall:   systemctl stop firewalld.service #停止firewall systemctl disable firewalld.service #禁止firewall开机…

    Linux干货 2016-06-23
  • LINUX初次见面

    LINUX的文件系统 在Linux的眼睛中,一切都为文件,这也是Linux的中心哲学思想。正因如此造就了一个性能稳定,功能强大,效率高的操作系统。Linux有自己的层级标准,它定义了每个系统分区的用途,和所需要的最小构成文件目录。由不同的文件来完成不同的功能造就了一个Linux的完整生态。 linux的文件系统格式比较丰富,它的核心系统能支持十多种文件系统类…

    2017-05-18
  • Linux中Vim编辑器的使用

    Linux中Vim编辑器的使用 Vim功能介绍 vim是一款功能丰富而强大的文本编辑器,支持语法高亮,支持多窗口编辑,是vi文本编辑器的增强版。如果在CentOS7.2中如果是选择最小化安装,其默认是没有安装vim rpm包的,需要自行安装,可以使用yum工具进行在线安装。  vim至今已经走过了25个春秋,现在8.0版的已经发布了。  …

    Linux干货 2016-12-02
  • N25-第8周博客作业

    第八周 1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态; 在线的主机使用绿色显示; 不在线的主使用红色显示; #!/bin/bash # ip=172.16.250. for i in {1..254}; do if ping -w 1 -c 1 $ip$i &> /dev/n…

    Linux干货 2017-03-10

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-02 17:09

    概念性的知识可以总结在详细一些,加油!