reactor模式

1.初级的服务器:
while(true){
socket = accept();
handle(socket)
}
对于请求只能一个个的来接受。
2.第二级别的服务器
while(true){
socket = accept();
new thread(socket);
}
这时候可以支持多个请求一起回答了,但是对资源的要求明显变高了,而且一点线程的粒度变得十分的大。
一次服务端正常的相应,是这么一个过程,read --》decode --》compute —》 encode --》send。很明显
3.reactor 模式
2中的方式线程力度太大,从而限制了吞吐量。一次read 可以读取多个请求的数据,然后根据协议转化过来。这样read 只需要专注干这件事情,而且提高了吞吐量。


mainReactor负责监听连接,accept连接给subReactor处理,为什么要单独分一个Reactor来处理监听呢?因为像TCP这样需要经过3次握手才能建立连接,这个建立连接的过程也是要耗时间和资源的,单独分一个Reactor来处理,可以提高性能。

你可能感兴趣的:(netty)