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

文章目录

    • 心跳包
    • 高并发的三种解决办法
      • 阻塞等待
      • 非阻塞忙轮询
      • 多路IO转接(多路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);
除了不可跨平台,优点有描述符无上限
事件回调,不会随着描述符的增加,性能下降
每个事件只需添加到内核态一次,不需要重复添加

你可能感兴趣的:(linux,socket)