news 2026/6/16 20:49:41

41、Linux 网络编程并发模型总结(select / epoll / fork / pthread)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
41、Linux 网络编程并发模型总结(select / epoll / fork / pthread)

Linux 网络编程并发模型总结(select / epoll / fork / pthread)

一、实验环境与基础说明

1. 实验环境

  • 操作系统:Linux(Ubuntu)
  • 通信协议:TCP
  • 地址族:AF_INET
  • 端口号:50000
  • 客户端模型:阻塞式 TCP 客户端
  • 服务端模型:多种并发处理方式

2. TCP 基本通信流程

所有实验代码都遵循 TCP 通信的基本流程:

服务器端
socket → bind → listen → accept → recv/send → close
客户端
socket → connect → send/recv → close

二、select 并发服务器模型

1. 核心思想

select通过一个文件描述符集合(fd_set),同时监听多个 socket,当某个 fd 就绪时再进行处理。

本质:I/O 多路复用(同步阻塞)


2. 实现要点

  • 使用fd_set保存监听的 fd

  • select()阻塞等待事件发生

  • 区分监听套接字和通信套接字:

    • listfd:处理新连接(accept)
    • connfd:处理客户端数据
FD_SET(listfd,&tmp_set);select(maxfd+1,&rd_set,NULL,NULL,NULL);

3. 特点分析

✅ 优点:

  • 跨平台(POSIX)
  • 编程模型简单
  • 适合少量并发连接

❌ 缺点:

  • 每次 select 都要遍历 fd
  • fd 数量有限(通常 1024)
  • 大量连接时性能急剧下降

📌适用场景
教学实验、小规模并发服务器


三、epoll 并发服务器模型

1. 核心思想

epoll是 Linux 提供的高性能 I/O 多路复用机制,采用事件驱动模型。

本质:事件通知 + 回调式处理


2. epoll 工作流程

epoll_create → epoll_ctl(add) → epoll_wait → 处理事件
epoll_add_fd(epfd,listfd);epoll_wait(epfd,events,MAX_EVENTS,-1);

3. 特点分析

✅ 优点:

  • 支持大量并发连接
  • O(1) 时间复杂度
  • 不需要遍历全部 fd
  • 高性能、高扩展性

❌ 缺点:

  • 仅支持 Linux
  • 编程复杂度高于 select

📌适用场景
高并发服务器(Web 服务器、即时通信)


四、fork 多进程服务器模型

1. 核心思想

每接入一个客户端,服务器fork()一个子进程专门处理该连接。

pid_tpid=fork();if(pid==0){// 子进程处理客户端}

2. 特点分析

✅ 优点:

  • 实现简单
  • 进程隔离,稳定性好
  • 单个进程崩溃不影响其他连接

❌ 缺点:

  • 进程创建开销大
  • 上下文切换成本高
  • 不适合高并发场景

📌适用场景
早期 Unix 服务、低并发、可靠性优先场景


五、pthread 多线程服务器模型

1. 核心思想

每个客户端连接由一个线程处理,共享进程资源。

pthread_create(&tid,NULL,thread_func,&conn);

2. 同步问题

代码中使用了信号量sem_t,防止主线程与子线程之间的竞争:

sem_init(&sem_cli,0,0);sem_wait(&sem_cli);

3. 特点分析

✅ 优点:

  • 资源共享,通信效率高
  • 创建开销小于进程
  • 编程灵活

❌ 缺点:

  • 需要处理线程同步
  • 线程安全问题复杂
  • 单线程崩溃可能影响整个进程

📌适用场景
中等并发服务器、业务逻辑复杂的应用


六、四种模型对比总结

模型并发能力资源开销编程难度适用场景
select⭐⭐教学、小规模
epoll⭐⭐⭐⭐高并发服务器
fork⭐⭐稳定性优先
pthread中高⭐⭐⭐通用服务器

七、实验心得总结

  • select → epoll是 I/O 多路复用的进阶路径
  • fork → pthread是并发执行模型的两种典型方案
  • 高并发场景下,epoll + 线程池 / 协程是主流方案
  • 实际工程中常常是多种模型组合使用
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 14:56:29

PyTorch镜像中使用tensorboardX记录训练指标

PyTorch镜像中使用tensorboardX记录训练指标 在深度学习项目开发过程中,一个常见的痛点是:明明代码逻辑正确,模型结构也无误,但训练几小时后才发现损失不降、准确率上不去——而此时却没有任何中间过程可供排查。这种“黑盒训练”…

作者头像 李华
网站建设 2026/6/15 14:53:21

2025最新!专科生必看9款AI论文软件测评:开题报告文献综述神器推荐

2025最新!专科生必看9款AI论文软件测评:开题报告&文献综述神器推荐 2025年专科生论文写作工具测评:精准推荐,高效提效 随着AI技术的不断进步,越来越多的学术辅助工具走进了高校学生的日常学习中。对于专科生而言&a…

作者头像 李华
网站建设 2026/6/15 14:07:02

jiyutrainer下载提供PyTorch-CUDA-v2.8离线安装包

jiyutrainer 提供 PyTorch-CUDA-v2.8 离线安装包 在高校实验室的深夜机房里,一个学生正对着满屏红色报错发愁:“CUDA not available”——这可能是每个刚接触深度学习的人都经历过的噩梦。明明买了高端显卡,却只能用 CPU 跑模型;明…

作者头像 李华
网站建设 2026/6/15 19:23:17

SSH远程连接PyTorch容器:Linux命令行开发全流程

SSH远程连接PyTorch容器:Linux命令行开发全流程 在现代深度学习项目中,越来越多的团队将计算密集型任务迁移到配备多块高性能GPU的远程服务器上。然而,这些设备通常位于数据中心或云平台,无法直接操作。一个常见的场景是&#xff…

作者头像 李华