缺点: client和server一旦建立连接,就可以建立通信套接字在这个通信套接字上进行读写操作,此时不能再接收其他客户端连接请求,只能等待同当前连接的客户端的操作执行完成。
缺点: 变更触发轮询查找,有1024数量上限
好处: 变更触发回调函数直接读取,理论无上限
允许其做平滑重启和平滑重新加载配置且不会断开与客户端连接
当worker进程挂掉或者管理员执行重启命令,master进程不会挂掉,master进程会向worker进程发送一个信号,让worker将所有的sockert句柄都让master进程管理,master进程会重新加载配置文件,启动一个新的worker进程,并且将管理的socket句柄交给新创建的worker进程管理,全部操作都是基于内存,瞬时完成.(基于worker进程是master进程fork出来的子进程,master进程共享所有worker进程变量)
完成单进程上单线程的模型,同时可以支持并发的编程的调用接口
协程是一个比线程更小的概念,一个线程可以有多个协程,协程的切换开销极小,因为它没有像线程切换一样有CPU的切换开销,只需要一个内存的切换开销即可.
当执行socket.read的时候,nginx对应的协程机制会自动将对应的协程的执行权限剥夺,并调出一个不堵塞的协程运行,当socker.read操作完成,epoll的多路复用机制会回调通知worker,这个回调直接是方法的return.
协程依附于线程,是一个串行执行的过程,不需要加锁.