当前位置: 首页 > news >正文

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 + 线程池 / 协程是主流方案
  • 实际工程中常常是多种模型组合使用
http://www.jsqmd.com/news/162180/

相关文章:

  • 自定义Java命令行的编译运行脚本
  • PyTorch镜像能否用于生产环境?稳定性测试结果公布
  • PyTorch-CUDA-v2.8镜像环境变量配置说明
  • OceanBase 数据库 TPCH ACID 测试
  • Unity游戏翻译高效解决方案:XUnity.AutoTranslator完整使用指南
  • 利用OpenAMP提升工控系统响应速度:深度剖析
  • 2025年终四川用友公司推荐:聚焦本地化案例的5强口碑榜单深度解析。 - 十大品牌推荐
  • 基于S7-200 PLC和组态王软件设计的智能快件分拣系统:技术详解与实现图谱
  • DownKyi完整使用指南:从零开始掌握B站视频下载
  • PyTorch镜像中实现模型剪枝与稀疏化操作
  • 图解说明蜂鸣器驱动电路连接方式与原理
  • PyTorch镜像运行AutoML任务:自动化超参搜索实战
  • 会用 Grid 布局吗?面试官问我这个问题,我差点没答上来!
  • PyTorch-CUDA镜像能否用于边缘设备部署?
  • PyTorch镜像中运行SimCLR自监督学习任务
  • PyTorch-CUDA镜像能否用于自动驾驶感知模块开发?
  • PyTorch-CUDA-v2.8镜像SSH连接教程:远程开发全流程解析
  • 2025 搜索优化新革命:GEO 正在悄然取代 SEO?
  • PyTorch-CUDA镜像是否支持Windows系统?答案在这里
  • PyTorch镜像中运行Streamlit构建可视化界面
  • PyTorch镜像中如何安装额外包?pip与conda使用建议
  • PyTorch镜像中运行BERT文本分类全流程演示
  • PyTorch-CUDA-v2.8镜像支持哪些NVIDIA显卡型号?
  • PyTorch-CUDA-v2.8镜像是否预装ray?分布式计算支持
  • 电机控制器中的滑模观测器PMSM无感矢量控制仿真研究:PLL与arctan开关设置下的性能探讨...
  • PyTorch镜像中使用tensorboardX记录训练指标
  • COOFDM的Matlab仿真程序详解:从代码实现到理论解析的综合指南
  • PyTorch镜像中如何安装nvtop监控GPU温度?
  • 【路径规划】基于A、RRT、目标偏向 RRT、路径裁剪目标偏向RRT、APFG-RRT、RRT-Connect 六种主流路径规划算法实现机器人路径规划附matlab代码
  • ViGEmBus虚拟游戏手柄驱动:让所有手柄在PC上畅玩游戏的终极指南