第十三篇:socket套接字

TCP sokcet调用过程:

具体代码参考:https://blog.csdn.net/xiadeliang1111/article/details/85210205

udp socket调用过程:

具体代码参考:https://blog.csdn.net/xiadeliang1111/article/details/104658548

 


以上实现,性能方面会有很大限制,如果让服务器高性能处理更多的请求。

 

1、IO多路复用

->思路:单进程(非多线程)调用select()函数来处理多个连接请求。

->优点:单进程(非多线程)可支持同事处理多个网络连接请求。

->缺点:最大并发为1024个,当并发数较大时,其处理性能很低。

 

2、多进程模型

->思路:当连接请求过来时,主进程fork产生一个子进程,让子进程负责与客户端连接进行数据通信,当客户端主动关闭连接后,子进程运行结束。

->优点:模式简单,易于理解;连接请求很小时,效率很高。

->缺点:当连接请求过多时,系统资源很快被耗尽。比如:当连接请求达到10K时,难道要启动10K个进程吗?

 

3、多线程模型

->思路:首先启动多个工作线程,而主线程负责接收客户端连接请求,工作线程负责与客户端通信;当连接请求过来时,ACCEPT线程将sckid放入一个数组中,工作线程中的空闲线程从数组中取走一个sckid,对应的工作线程再与客户端连接进行数据通信,当客户端主动关闭连接后,此工作线程又去从指定数组中取sckid,依次重复运行。

->优点:拥有方案二的优点,且能够解决方案2的缺点

->缺点:不能支持并发量大的请求和量稍大的长连接请求。

 

4、IO多路复用,epoll模型

 

参考:https://blog.csdn.net/qq_28098067/article/details/80501750

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值