访问网站的方式

  • 基于IP访问
  • 基于域名访问
  • IP + PORT
  • 域名 + port


服务端中Nginx通过端口接收到http报文请求之后,通过报文中请求域名与自己配置文件中的server模块中的server_name进行匹配
交给location模块匹配所请求的uri信息,根据响应进行规则处理
通过调用内核,由内核调用磁盘,取得响应,封装并返回给用户、

一个小现象:
如果存在两份配置文件都监听同一个端口,则默认会读取排在前面的那一份配置文件
如下
在这里,nginx优先读取了 Linux-test1.conf

  1. [root@localhost conf.d]# cat Linux-test1
  2. Linux-test11.conf Linux-test1.conf
  3. [root@localhost conf.d]# cat Linux-test1
  4. Linux-test11.conf Linux-test1.conf
  5. [root@localhost conf.d]# cat Linux-test1.conf
  6. server {
  7. listen 8080; #指定监听哪个端口
  8. server_name www.test.com; #访问该服务通过哪个域名来访问
  9. location / { #语法 location uri 所有访问上方定义的域名的用户 都到这个路径来
  10. root /html/game; #存放源码的目录
  11. index tndex.html; #定义首页文件
  12. }
  13. }
  14. [root@localhost conf.d]# cat Linux-test11.conf
  15. server {
  16. listen 8080; #指定监听哪个端口
  17. server_name www.test.com; #访问该服务通过哪个域名来访问
  18. location / { #语法 location uri 所有访问上方定义的域名的用户 都到这个路径来
  19. root /html/game; #存放源码的目录
  20. index index.html; #定义首页文件
  21. }
  22. }
  23. [root@localhost conf.d]#

image.png

处理细节

由于web服务器与客户端是一对多的关系,web服务器必须有能力同时为多个客户端提供服务。一般完成并行处理请求的工作方式有三种:多进程、多线程、异步

多进程

多进程的方式是指,服务器每当收到一个客户端时,就由服务器主进程生成一个子进程来和该客户端建立连接进行交互,直到连接断开,该子进程就结束了。

多线程

多线程是指,服务器每当收到一个客户端时,就由服务器主进程派生出一个线程来与该客户端进行交互。
image.png

异步方式

前置概念:同步、异步、阻塞、非阻塞
链接:https://www.zhihu.com/question/19732473/answer/20851256

  1. “阻塞”与"非阻塞""同步"与“异步"不能简单的从字面理解,提供一个从分布式系统角度的回答。
  2. 1.同步与异步同步和异步关注的是消息通信机制 (synchronous communication/ asynchronous communication)
  3. 所谓同步,就是在发出一个*调用*时,在没有得到结果之前,该*调用*就不返回。但是一旦调用返回,就得到返回值了。换句话说,就是由*调用者*主动等待这个*调用*的结果。而异步则是相反,*调用*在发出之后,这个调用就直接返回了,所以没有返回结果。
  4. 换句话说,当一个异步过程调用发出后,调用者不会立刻得到结果。而是在*调用*发出后,*被调用者*通过状态、通知来通知调用者,或通过回调函数处理这个调用。
  5. 典型的异步编程模型比如Node.js举个通俗的例子:你打电话问书店老板有没有《分布式系统》这本书,如果是同步通信机制,书店老板会说,你稍等,”我查一下",然后开始查啊查,等查好了(可能是5秒,也可能是一天)告诉你结果(返回结果)。
  6. 而异步通信机制,书店老板直接告诉你我查一下啊,查好了打电话给你,然后直接挂电话了(不返回结果)。然后查好了,他会主动打电话给你。在这里老板通过“回电”这种方式来回调。
  7. 2. 阻塞与非阻塞阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态.
  8. 阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
  9. 非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。
  10. 还是上面的例子,你打电话问书店老板有没有《分布式系统》这本书,你如果是阻塞式调用,你会一直把自己“挂起”,直到得到这本书有没有的结果,如果是非阻塞式调用,你不管老板有没有告诉你,你自己先一边去玩了, 当然你也要偶尔过几分钟check一下老板有没有返回结果。在这里阻塞与非阻塞与是否同步异步无关。跟老板通过什么方式回答你结果无关。

当这两个概念组合到一起,就会产生四个新的概念:
同步阻塞方式
发送方向接收方发送请求后,一支等待响应;接收方处理请求时进行的IO操作如果不能马上得到结果,就一支等到返回的结果然后才响应发送方,期间不能进行其他工作。

异步阻塞方式
发送方向接收方发送请求后,不用等待响应,可以桀纣进行其他工作;接收方处理请求时进行的IO操作如果不能马上得到结果,就一直等返回结果后,才响应发送方,期间接收方不能进行其他工作。

同步非阻塞方式
发送方向接收方发送请求后,一支等待响应;接收方处理请求时进行的IO操作如果不能马上得到结果,就立即返回,去做其他的事情。但是由于没有得到请求的处理结果,接收方不会响应发送方,发送方一直等待,直到 IO操作完成后,接收方响应发送方。这时候接收方才能进入下一次请求过程。

异步非阻塞方式
发送方向接收方发送请求后,不用等待响应,可以继续其他工作;接收方处理请求时进行的IO操作不能马上得到结果,不进行等待,返回做其他的事情。当IO操作完成走以后,将完成的状态和结果通知接收方,接收方再响应发送方。

Nginx结合多进程和异步机制对外提供服务,异步机制选择的就是异步非阻塞。