TCP通信中的高并发(多路IO口转并发)

心跳包

在TCP网络通信中,经常会出现客户端和服务器之间的非正常断开,需要实时检测查询链接状态。常用的解决方法就是在程序中加入心跳机制。
设计一个守护进程,定时的发送一个数据包,客户端或服务器端收到和,会立即返回一个包,确定实时在线。

高并发的三种解决办法

TCP服务器端等待多个客户端建立连接。

阻塞等待

一个客户端创建一个进程或者一个线程,多客户端的话就会创建多个,会占用内存,并且这些进程或线程大多数都是休眠状态。

非阻塞忙轮询

用一个进程来不断的服务于客户端。如果客户端没有发来消息,也没有新的客户端请求连接,这个时候程序在做无用功,浪费cpu的资源。

多路IO转接(多路IO复用)

客户端大量链接,但同一时间活跃量较小。
一个进程,服务器端监测客户端的套接字,当时间发生,进行相应操作。
监听的三个函数
select函数
int select(int nfds, fd_set *readfds, fd_set *writefds,
fd_set *exceptfds, struct timeval *timeout);
缺点:
文件描述符有1024个,有限制
用户态拷贝至内核态
轮询遍历数组

poll函数
int poll(struct pollfd* fds, nfds_t nfds, int timeout);
缺点:
虽然描述符无限,但轮询遍历性能减低
epoll函数
int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);
除了不可跨平台,优点有描述符无上限
事件回调,不会随着描述符的增加,性能下降
每个事件只需添加到内核态一次,不需要重复添加

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值