服务端网络框架

生产者消费者模式

生产者的责任

  监听连接,有新连接到来时就接受并将其放入待检查集合内;

  检查请求,每当客户端有新数据到来时则将该连接放入待消费队列内,供消费者取用进行业务处理

  关闭连接,跟进select()、epoll_wait()的超时时长定时触发连接活动性检查,将超时无活动的socket关闭

  请求限流,当待消费队列内socket已达最大数量,则新的客户端连接将不再处理

消费者责任

  业务处理,读取客户端数据,逻辑处理,并返回结果。当处理完成后将该socket放入待检查队列

  超时放弃,待消费队列内滞留时间过长的socket直接放弃,因为很大几率客户端在请求超时无反应时已放弃等待

追随者

 

领导者追随者模式

每个线程都去抢占锁,加锁成功后即可accept()客户端连接,接受连接后则持续处理请求直到没有新请求过来,然后关闭该连接

  优点,处理简单

  缺点,无法做请求限流、超时放弃

抢占式

转载于:https://www.cnblogs.com/tianrks/p/10476064.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的网络服务端模块是一种用于构建网络服务器的工具,可以根据具体的需求选择适合的模块,包括socket、asyncio、Twisted等。其中最常用的是socket模块,它能够方便地创建套接字并监听端口,接受客户端的连接请求并进行通信。 在Python中,我们可以使用socket模块快速地建立一个简单的网络服务端,只需几行代码即可实现。通过socket模块,我们可以实现基于TCP或UDP协议的网络通信,处理客户端发送过来的数据并给予相应的回复。 另外,Python中的asyncio模块也是一个很强大的工具,它基于协程的方式实现异步的网络编程,可以处理大量的并发连接请求,提高服务器的性能和处理能力。使用asyncio模块,我们可以编写高效的网络服务端程序,处理多个客户端的请求并发地进行通信。 此外,Twisted是另一个流行的网络编程框架,它提供了丰富的工具和组件,能够轻松地构建高性能的网络服务端。Twisted框架支持多种协议,包括HTTP、SMTP、POP3等,可以用于构建各种类型的网络应用程序。 总之,Python拥有丰富的网络服务端模块,无论是简单的套接字通信,还是高级的异步网络编程,都能够很好地满足我们的需求。开发者可以根据具体的应用场景和需求选择合适的网络服务端模块,并利用其提供的强大功能快速地实现网络应用程序的开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值