news 2026/6/4 16:30:06

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/5/28 14:58:33

PyTorch-CUDA-v2.8镜像对GPT系列模型的兼容性测试

PyTorch-CUDA-v2.8镜像对GPT系列模型的兼容性测试 在当前大模型研发如火如荼的背景下,一个稳定、高效且开箱即用的深度学习运行环境,已经成为AI工程师日常开发中的“刚需”。尤其是在训练和部署GPT类大规模语言模型时,动辄数十GB显存占用、复…

作者头像 李华
网站建设 2026/5/30 15:33:44

GDP-D-甘露糖二钠盐 —— 糖基化研究与治疗开发的核心糖核苷酸 148296-46-2

GDP-D-甘露糖二钠盐是糖核苷酸家族中至关重要的成员,在细胞糖基化进程中扮演着不可替代的角色。作为甘露糖残基的关键活化供体,它直接参与蛋白质和脂质的翻译后修饰,影响其结构、稳定性与生物功能。从基础生物化学研究到前沿生物制药开发&…

作者头像 李华
网站建设 2026/5/28 18:01:23

当“风光火电“抱团取暖

[1]关键词:合作博弈;核仁法;混合能源;联合外送;经济运行;利润分配;matlab程序 [2]参考文献:《大规模多源联合外送协调调度中基于核仁理论的利润分配》 [3]主要内容:研究了在大规模风…

作者头像 李华