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来处理,可以提高性能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值