其他分享
首页 > 其他分享> > 初夏小谈:基于TCP协议的网络通信(线程池实现)

初夏小谈:基于TCP协议的网络通信(线程池实现)

作者:互联网

一、TCP通信网络中可能用到的接口:

1.创建套接字

int socket(int domain, int type, int protocol);

2.绑定地址信息和端口

int bind(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

3.开始监听:告诉操作系统可以开始与用户进行三次握手连接;每一个客户端到来都会为它创建一个新的socket与它单独通信,为了防止而已连接攻击服务器设置backlog来限制最大并发连接数。在内核中已经创建连接队列和未完成的对列,通过最大节点数量来限制。

int listen(int sockfd, int backlog);

4.获取上一步已完成连接的客户端新建socket。

int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);

sockfd:监听socket。仅用于接收第一次请求。在后续通信中它不再使用。与客户端进行通信。

5.收发数据

ssize_t recv(int sockfd, void *buf, size_t len, int flags);

recv返回值为0,不是没有数据,而是断开连接。

ssize_t send(int sockfd, const void *buf, size_t len, int flags);

6.客户端连接请求:

int connect(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

二、TCP协议通信注意事项:

由于基本的TCP服务端程序同时只能与一个客户端进行通信:因为服务器并不知道客户端数据什么时候到来,因此服务端程序流程只能写死,而写死可能会导致阻塞

所以就使用多进程/多线程来处理。

在多进程tcp服务端程序:一个子进程处理一个客户端,实现多个客户端同时处理。父进程必须关闭socket,处理僵尸子进程问题。设置信号。

在多线程tcp服务端程序:一个子线程处理一个客户端,实现多个客户端的同时处理。主线程不能退出即不能关闭socket:线程间共享代码段,数据段。同一线程共享文件描述符表。

三、代码实现:

1.实现TCP通信所需的所有函数的接口类:

2.实现线程池版本的服务端:

3.客户端程序:

4.运行结果:

4.1服务端显示:

4.2客户端jack:

4.3客户端小明:

4.4客户端peter:

                                                                                                                                                           珍&源码

标签:socket,小谈,int,TCP,线程,sockfd,服务端,客户端
来源: https://blog.csdn.net/IT_xiaoQ/article/details/90607592