两种高效的服务器并发模式

高并发在I/O密集型任务中能提升CPU利用率,但对计算密集型任务可能适得其反。半同步/半异步模式中,同步线程处理业务逻辑,异步线程处理I/O事件,通过请求队列协调。领导者/追随者模式则通过轮流监听I/O事件,确保高效并发,避免单点阻塞。
摘要由CSDN通过智能技术生成

高并发的目的就是提高CPU的使用率,使得程序可以“同时”执行多个任务。一旦程序中发生阻塞,则其他程序能立即执行,不会阻塞从而降低CPU的使用率。
不过对于计算密集型的程序,高并发编程反而没有优势,因为任务的切换降低了效率。但是如果是I/O密集型,经常读写文件、访问数据库等等,I/O操作的熟读远没有CPU计算速度快,所以会显著降低了CPU的执行效率。
并发模式指的是I/O处理单元和多个逻辑单元协调完成任务的方法。有两种方法:半同步/半异步模式领导者/追随者 模式。

半同步/半异步模式

这里的同步指的是程序完全按照代码序列的顺序执行。而异步指的是程序的执行需要系统事件来驱动,包括中断或者信号等。
在这里插入图片描述
在并发模式中,同步 指的是程序按照代码序列的顺序执行。异步 指的是程序的执行需要有系统事件来驱动,类似于信号、中断等等。同步线程代码简单、实时性比较差,而异步线程效率高,实时性强,但程序复杂、难以调试和扩展。所以对于服务器这种既要要求较好的实时性,又要求同时处理多个客户请求的应用程序,通常采用半同步/半异步的实现
其中,同步线程处理客户逻辑,而异步线程处理I/O事件, 在监听到客户请求之后,将其封装成请求对象插入请求队列,请求队列在通知同步模式的某个线程来读取并处理请求对象。在这里插入图片描述
在此模型中,异步线程只有一个,是主线程来监听socket上所有的事件。如果监听到socket上的可读事件,此时主线程接受新的链接socket,往EPOLL的内核事件表中注册该socket上的读写事件。所有的工作线程都睡免灾请求队列中,当有任务来临的时候,通过竞争获得任务的接管权。

领导者/追随者模式

这种高效的模式指的是多个工作线程轮流获取事件源集合,轮流监听、分发处理事件。任意时间点,程序都只有一个领导者线程来坚挺I/O事件。此时其他的线程都是追随者,等待成为新的领导者。当前的领导者如果检测到I/O事件,首先从线程池中推选出心得领导者线程,来处理I/O事件。此时新领导者等待监听就绪IO,而旧领导者变成了追随者,来处理IO,实现了并发在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值