news 2026/7/4 2:59:03

TCP并发实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
TCP并发实现

文章目录

  • TCP服务端
    • 基础服务端
    • TCP服务设计模式
      • 迭代服务(一次处理一个客户端)
      • 多进程并发服务
        • 僵尸进程处理(信号处理)
      • 多线程并发服务
        • 嵌入式设备线程注意
  • TCP客户端
    • 基础客户端
      • 交互式客户端
    • 客户端断线重连机制

TCP服务端

基础服务端

// 基础TCP服务器核心流程#defineBUFFER_SIZE1024// 根据设备内存自定义charbuf[BUFFER_SIZE];intmain(){// 1. 创建socketfd=socket(AF_INET,SOCK_STREAM,0);// 2. 准备地址结构addr.sin_family=AF_INET;addr.sin_port=htons(PORT);addr.sin_addr.s_addr=0;// INADDR_ANY的另一种写法// 3. 绑定地址bind(fd,(structsockaddr*)&addr,sizeof(addr));// 4. 开始监听listen(fd,BACKLOG);// 5. 接受连接(阻塞等待)newfd=accept(fd,NULL,NULL);// 不关心客户端地址// 6. 接收数据read(newfd,buf,BUFFER_SIZE);// 7. 关闭连接close(newfd);close(fd);return0;}

TCP服务设计模式

迭代服务(一次处理一个客户端)

// 简化的迭代服务器框架while(1){client_fd=accept(server_fd,NULL,NULL);if(client_fd<0)continue;handle_client(client_fd);// 处理客户端请求close(client_fd);// 处理完后关闭}

缺点:无法并发处理多个客户端

多进程并发服务

// 父进程:监听连接,创建子进程处理// 子进程:处理具体客户端请求,结束后退出pid_tpid=fork();if(pid==0){// 子进程close(server_fd);// 关闭不需要的监听sockethandle_client(client_fd);close(client_fd);exit(0);// 子进程结束}else{// 父进程close(client_fd);// 父进程关闭已分发的客户端socketwaitpid(-1,NULL,WNOHANG);// 非阻塞回收子进程}
僵尸进程处理(信号处理)
// 使用信号处理函数回收子进程voidsigchld_handler(intsig){while(waitpid(-1,NULL,WNOHANG)>0){// 回收所有已终止的子进程}}// 注册信号处理器signal(SIGCHLD,sigchld_handler);// 更推荐使用sigaction(可重启系统调用)structsigactionsa;sa.sa_handler=sigchld_handler;sigemptyset(&sa.sa_mask);sa.sa_flags=SA_RESTART|SA_NOCLDSTOP;sigaction(SIGCHLD,&sa,NULL);

多线程并发服务

// 主线程:监听连接,创建子线程// 工作线程:处理客户端请求void*client_handler(void*arg){intclient_fd=*(int*)arg;// 处理客户端...close(client_fd);returnNULL;}// 创建线程处理每个客户端pthread_ttid;int*client_fd_ptr=malloc(sizeof(int));*client_fd_ptr=client_fd;pthread_create(&tid,NULL,client_handler,client_fd_ptr);pthread_detach(tid);// 分离线程,自动回收资源
嵌入式设备线程注意
// 1. 设置线程栈大小(嵌入式内存有限)pthread_attr_tattr;pthread_attr_init(&attr);pthread_attr_setstacksize(&attr,8192);// 8KB栈空间// 2. 线程池模式(避免频繁创建销毁线程)// 3. 注意线程安全,共享数据加锁

TCP客户端

基础客户端

// 核心流程intmain(){// 1. 创建socketfd=socket(AF_INET,SOCK_STREAM,0);// 2. 设置服务器地址addr.sin_family=AF_INET;addr.sin_port=htons(PORT);addr.sin_addr.s_addr=inet_addr("127.0.0.1");// 3. 连接服务器connect(fd,(structsockaddr*)&addr,sizeof(addr));// 4. 发送数据write(fd,STR,sizeof(STR));// 5. 关闭连接close(fd);}

交互式客户端

// 支持命令行参数和交互式输入intmain(intargc,char*argv[]){// 检查参数if(argc<3){fprintf(stderr,"用法: %s <IP地址> <端口>\n",argv[0]);exit(EXIT_FAILURE);}// 解析参数char*server_ip=argv[1];intserver_port=atoi(argv[2]);// 创建socket和连接...// 交互循环while(1){printf("请输入消息: ");fgets(buf,BUFSIZ,stdin);// 发送数据intn=write(fd,buf,strlen(buf));if(n<=0){perror("发送失败");break;}// 可选:接收服务器响应// n = read(fd, response, sizeof(response));}}

客户端断线重连机制

// 嵌入式设备常用,增加连接稳定性#defineMAX_RETRY5#defineRETRY_DELAY3// 秒intconnect_with_retry(constchar*ip,intport,intmax_retry){intsockfd;structsockaddr_inaddr;for(intretry=0;retry<max_retry;retry++){sockfd=socket(AF_INET,SOCK_STREAM,0);if(sockfd<0){perror("创建socket失败");return-1;}memset(&addr,0,sizeof(addr));addr.sin_family=AF_INET;addr.sin_port=htons(port);inet_pton(AF_INET,ip,&addr.sin_addr);if(connect(sockfd,(structsockaddr*)&addr,sizeof(addr))==0){printf("连接成功(第%d次尝试)\n",retry+1);returnsockfd;}close(sockfd);printf("连接失败,%d秒后重试...\n",RETRY_DELAY);sleep(RETRY_DELAY);}fprintf(stderr,"连接失败,达到最大重试次数\n");return-1;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/2 2:42:09

RAG不是魔法,是工程:从知识库到企业部署的硬核实践

前言 大模型热潮席卷技术圈&#xff0c;但真正将其用于企业生产环境的人很快会发现&#xff1a;开箱即用的聊天机器人远不能满足业务需求。模型会胡说八道&#xff0c;回答不了昨天刚发布的新政策&#xff0c;更不敢把客户合同上传到公有云API。这时候&#xff0c;RAG&#xf…

作者头像 李华
网站建设 2026/7/2 2:40:29

为什么几乎所有大厂,都在选 Go ?

沉默是金&#xff0c;总会发光大家好&#xff0c;我是沉默这几年&#xff0c;你会发现一个非常明显的趋势&#xff1a;腾讯、美团、滴滴、百度字节跳动&#xff08;早期 Python&#xff0c;如今全面 Go 化&#xff09;Google、bilibili……国内外头部互联网公司&#xff0c;几乎…

作者头像 李华
网站建设 2026/7/4 1:37:43

10.BTC-分叉-北大肖臻老师客堂笔记

北京大学肖臻老师《区块链技术与应用》公开课第 10 讲的主题是**“比特币的分叉&#xff1a;硬分叉与软分叉”**。这节课非常重要&#xff0c;因为它解释了在去中心化系统中&#xff0c;当协议&#xff08;规则&#xff09;发生升级时&#xff0c;网络是如何达成共识&#xff0…

作者头像 李华
网站建设 2026/7/3 11:42:30

智能包装行业发展趋势下,如何提高竞争力?

在当前快速发展的智能包装行业中&#xff0c;中科天工包装技术正在利用其技术优势积极布局市场。通过研发更高效的智能包装设备&#xff0c;中科天工致力于满足不断变化的市场需求。公司在技术创新上持续投入&#xff0c;推出具备自动化和智能管理功能的设备。这些设备不仅提升…

作者头像 李华
网站建设 2026/7/1 20:29:57

Dify 官方上架 Nacos A2A 插件,补全双向多智能体协作能力

作者&#xff1a;濯光 一、背景与挑战&#xff1a;多智能体协作中的典型问题 随着 AI Agent 技术的快速发展&#xff0c;单一智能体已经难以满足复杂业务场景的需求。多智能体协作&#xff08;Multi-Agent Collaboration&#xff09;正在成为 AI 应用的新趋势——让多个具备不…

作者头像 李华