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

网络编程epoll和udp

# epoll模型核心要点
## 1. epoll核心概念
### 1.1 高效IO多路复用
- 监视列表与激活列表分离
- 内核使用红黑树存储描述符
- 边缘触发模式(EPOLLET)支持
### 1.2 事件触发机制
- **水平触发(LT)**:
- 默认模式,类似select/poll
- 数据未读完持续触发事件
- **边缘触发(ET)**:
- 需手动设置EPOLLET标志
- 数据到达仅触发一次事件
- 必须搭配非阻塞IO使用
## 2. 关键操作函数
### 2.1 epoll_create1
```c
int epfd = epoll_create1(EPOLL_CLOEXEC);
  • 创建epoll实例
  • EPOLL_CLOEXEC标志自动关闭文件描述符

2.2 epoll_ctl

epoll_ctl(epfd, EPOLL_CTL_ADD, fd, &event);
  • 操作类型:
    • EPOLL_CTL_ADD 添加描述符
    • EPOLL_CTL_MOD 修改事件
    • EPOLL_CTL_DEL 删除描述符
  • 事件结构体:
    struct epoll_event {
    uint32_t events; // EPOLLIN/EPOLLOUT/EPOLLERR
    epoll_data_t data; // 携带用户数据
    };

2.3 epoll_wait

int num = epoll_wait(epfd, events, maxevents, timeout);
  • 阻塞等待事件触发
  • 参数:
    • timeout=-1永久阻塞
    • timeout=0非阻塞
  • 返回激活事件数量

3. 服务器实现流程

3.1 初始化阶段

// 创建TCP套接字
int sfd = socket(AF_INET, SOCK_STREAM, 0);
// 绑定地址
bind(sfd, (struct sockaddr*)&addr, sizeof(addr));
// 设置监听队列
listen(sfd, 5);
// 创建epoll实例
int epfd = epoll_create1(EPOLL_CLOEXEC);

3.2 事件处理循环

  1. 接受新连接
int client_fd = accept(sfd, ...);
// 设置非阻塞模式
fcntl(client_fd, F_SETFL, O_NONBLOCK);
// 添加至epoll监视
epoll_ctl(epfd, EPOLL_CTL_ADD, client_fd, &event);
  1. 处理数据接收
while(recv() > 0) { // 边缘触发需循环读取
printf("Received: %s", buf);
if(errno == EAGAIN) break; // 非阻塞模式退出条件
}
  1. 异常处理
if(ret == 0) { // 客户端关闭
epoll_ctl(epfd, EPOLL_CTL_DEL, fd_temp, NULL);
close(fd_temp);
}

4. 模型对比

特性selectpollepoll
数据结构位图(1024限制)结构体数组红黑树
时间复杂度O(n)线性扫描O(n)线性扫描O(1)回调通知
触发模式仅水平触发仅水平触发支持边缘触发
内存拷贝每次全量复制每次全量复制增量操作
适用场景低并发/跨平台中等并发高并发/Linux专用

5. 客户端实现要点

5.1 非阻塞IO设置

int flags = fcntl(fd, F_GETFL);
fcntl(fd, F_SETFL, flags | O_NONBLOCK);

5.2 数据发送处理

while(1) {
fgets(buf, sizeof(buf), stdin);
send(sfd, buf, strlen(buf), 0); // 边缘触发需保证完全发送
if(errno == EAGAIN) usleep(1000); // 流量控制
}

6. 特殊场景处理

6.1 多客户端通信

  • 服务端维护客户端映射表
  • 使用epoll_data携带会话上下文
event.data.ptr = &client_ctx; // 传递自定义数据结构

6.2 心跳检测机制

  • 定时器队列管理连接状态
  • EPOLLERR事件处理异常断开

# UDP套接字通信核心要点
## 1. UDP协议特性
### 基础特征
- 无连接不可靠传输
- 数据报独立发送
- 支持数据顺序错乱
- 效率高延迟低
### 适用场景
- 实时音视频传输
- 在线游戏数据交互
- 广播/组播通信
## 2. 核心函数解析
### socket创建
```c
int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
  • 协议族必须为AF_INET
  • 类型指定SOCK_DGRAM

数据接收

ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
struct sockaddr *src_addr, socklen_t *addrlen);
  • 获取发送方地址信息
  • flags支持阻塞/非阻塞模式

数据发送

ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,
const struct sockaddr *dest_addr, socklen_t addrlen);
  • 必须指定目标地址
  • 单次发送上限4096字节

connect特殊用法

  • 内核预存目标地址信息
  • 允许使用send/recv简化调用
  • 可多次调用更改目标地址

3. 服务器实现流程

核心步骤

  1. 创建DGRAM类型套接字
  2. 绑定固定IP和端口
  3. 循环接收客户端消息
  4. 响应消息附加处理标识

关键代码段

struct sockaddr_in cliaddr;
socklen_t len = sizeof(cliaddr);
ret = recvfrom(sockfd, buf, sizeof(buf), 0,
(struct sockaddr*)&cliaddr, &len);
sendto(sockfd, modified_buf, strlen(modified_buf), 0,
(struct sockaddr*)&cliaddr, len);

4. 客户端实现模式

基础版本

  • 每次发送指定目标地址
  • 内核自动管理地址缓存

高效版本

connect(sockfd, (struct sockaddr*)&seraddr, sizeof(seraddr));
send(sockfd, buf, strlen(buf), 0);
  • 内核持续存储目标地址
  • 减少地址解析开销

5. 特殊处理机制

地址重置

struct sockaddr_in unspec = { .sin_family = AF_UNSPEC };
connect(sockfd, (struct sockaddr*)&unspec, sizeof(unspec));
  • 清除内核缓存的地址
  • 恢复原始发送模式

错误检测

  • recvfrom返回0表示空数据包
  • errno==EAGAIN时处理非阻塞状态
  • 发送失败需重试或记录日志

6. 与TCP对比差异

特性UDPTCP
连接方式无连接三次握手建立连接
数据边界保留报文边界字节流形式
可靠性不保证数据完整可靠传输
资源消耗
适用场景实时性要求高的场景数据完整性场景

7. 性能优化方向

  • 使用连接式UDP减少系统调用
  • 设置SO_RCVBUF/SO_SNDBUF
  • 采用非阻塞IO+epoll多路复用
  • 实现应用层重传机制
http://www.xdnf.cn/news/404713.html

相关文章:

  • 华为防火墙配置与网络协议实战指南:从基础到高阶排查
  • 破局智算瓶颈:400G光模块如何重构AI时代的网络神经脉络
  • 大模型的实践应用41-天气预测与分析决策系统:Qwen3(32B)+langchain框架+MCP(大模型上下文协议)+RAG+传统算法
  • RabbitMQ高并发秒杀、抢购系统、预约系统底层实现逻辑
  • ArcGIS+InVEST+RUSLE:水土流失模拟与流域管理的高效解决方案;水土保持专题地图制作
  • 《Python星球日记》 第63天:文本方向综合项目(新闻分类)
  • 危化品安全员职业发展方向的优劣对比
  • 人工智能时代:解锁职业新身份,从“认证师”到“工程师”的进阶之路
  • 图灵爬虫练习平台第九题js逆向
  • 电力系统静态安全因素与动态安全因素的区别及具体分类
  • matlab计算天线的近场和远场
  • ThreadLocal原理分析--结合Spring事务
  • 产品设计基石--用户体验要素--实战4
  • 【课题推荐】基于改进遗传算法的公交车调度排班优化研究与实现方案
  • PID与模糊PID系统设计——基于模糊PID的水下航行器运动控制研究Simulink仿真(包含设计报告)
  • 在Web应用中集成Google AI NLP服务的完整指南:从Dialogflow配置到高并发优化
  • Codeforces Round 1024 (Div. 2)(A-D)
  • 1.8 梯度
  • FanControl(电脑风扇转速控制软件) v224 中文版
  • Blueprints - Gameplay Message Subsystem
  • js 字符串中的特殊字符全部替换成定义对象里面key对应的value值(基础篇)
  • C++ string比较、string随机访问、string字符插入、string数据删除
  • vue-pdf-embed预览PDF
  • mac M2能安装的虚拟机和linux系统系统
  • 寻找远程桌面管理器的5个关键功能
  • Spring Boot 使用Itext绘制并导出PDF
  • Docker Volumes
  • 一周学完计算机网络之三:1、数据链路层概述
  • 微信小程序单双周选择排序有效果图
  • Java游戏服务器开发流水账(6)网关服务器简介