同步异步是针对Server端而言,阻塞or非阻塞指的是Client端而言。
异步同步指的是服务提供者提供服务的方式,是立马服务,还是先接待,慢慢做,做完了,再通知你,客户无法立马得到服务。同步是 你要啥,当场就拿给你,异步是 你要啥,我记下了,我慢慢做,做好了,我通知你。
比如,饭店里一般都是异步的,你下单后,是先给你个号,做好了再通知你(通知有好几种方式,我放到你指定的位置,你自己去拿,一种是我通知你做好了,你自己过来拿,一种是自己主动不停的问:做好了吗?),不是立马为你服务。
阻塞非阻塞说的是服务需求者在得到服务反馈之前需不需要等待。
Reactor模型
一个Accptor线程,专门用来负责与Client建立连接,你可以类比到饭店门外的揽客的服务员,专门拉客进去消费的。
一个或多个EventLoop,用来负责接待顾客,你可以类比到饭店里服务接待顾客下单的服务员,你点菜,她会记录下来,然后把下单请求记录到系统,系统再把订单分派给厨师去异步处理。处理线程:就是真正干活的,类比饭店里的厨师。({江苏-互联网-零度} Reactor模型很多,可以是单线程模型、可以是多线程模型,也可以是主从多线程模型。)单线程模型就是同时只有一个厨师干活,干完了,下一个订单再派个厨师上来接着干。
来源:云原生后端社区
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。