Web 服务和I/O模型
前言:当前最为流行的Web服务器就属Httpd和Nginx。Web 服务器到底干了什么事?简单点说就是接受用户请求,响应用户请求。这个过程的实现就是完成了跨主机之间的通信,而主机间的通信我们使用的是BSD创建的Socket。Socket通信的模型如图1:
为了能够受到客户端的请求,客户端使用一个Socket监听在某个IP+Port之上。接受到请求,将客户端所要的资源准备好后,在响应给客户端。如果此时受到的请求不是一个,而是多个的话,服务器端要如何完成响应?如果一个一个的响应,显然太慢了。如何同时完成多个请求(并发响应)?接下来我们就是谈谈各种I/O模型,以及Httpd和Nginx中所使用的I/O模型。I/O模型
我们都知道程序员编写程序是一定会调用函数的,而一旦程序员调用了函数,也就意味着程序从主函数的上下文就入了函数的上下文。这时候有两个问题,一个是调用者(此情况下是主函数)要不要等被调用函数返回,另一个是被调用函数(被调用者)如何告诉调用者自己此时的状态。I/O模型的不同,实际上就是程序员调用的函数不同。调用的函数确定了也就意味着,调用者和被调用者采取那种行为方式也确定了。接下来我们从不同的角度看I/O模型的分类。
阻塞与非阻塞(从调用者的角度分类)
阻塞:当程序进入被调用者上下文时调用者会等被调用返回,调用者被挂起。程序执行流程图二左。
非阻塞:当程序进入被调用者上下文时,调用者也不会继续执行