0

0

Nginx针对epoll内存映射技术降低数据拷贝的原理

冷漠man

冷漠man

发布时间:2026-03-12 20:15:12

|

608人浏览过

|

来源于php中文网

原创

Nginx 的 epoll 不依赖 mmap 降低拷贝,其作用仅为高效通知就绪 fd;真正实现零拷贝的是 sendfile、splice 等机制,配合 sendfile on; 等配置优化数据路径。

nginx针对epoll内存映射技术降低数据拷贝的原理

Nginx 在 Linux 下使用 epoll 时,并不直接依赖内存映射(mmap)来降低数据拷贝。这是一个常见误解:epoll 本身是基于内核事件通知机制的 I/O 多路复用接口,它不涉及 mmap;而真正与“零拷贝”和减少数据拷贝相关的技术,是 sendfilesplicetcp_nopush/tcp_nodelay 等机制。Nginx 会结合这些机制,在特定场景下绕过用户态内存拷贝,但 epoll 仅负责高效就绪事件通知。

epoll 的作用:高效获取就绪连接,不参与数据搬运

epoll 的核心价值在于替代 select/poll,以 O(1) 时间复杂度管理海量连接:

  • 内核维护一个红黑树存储监听的 fd,一个就绪链表记录已触发事件的 fd
  • 调用 epoll_wait() 时,仅将就绪 fd 从内核链表复制到用户空间数组 —— 这次拷贝量极小(通常每个就绪事件仅 12 字节),与传输的数据量无关
  • epoll 不读取 socket 接收缓冲区数据,也不写入发送缓冲区;它只告诉 Nginx “哪个 fd 可读/可写”

真正减少数据拷贝的技术:sendfile 与 splice

当 Nginx 提供静态文件服务(如 HTML、图片)时,为避免将文件内容从内核页缓存 → 用户态缓冲区 → socket 发送缓冲区的两次拷贝,它会启用:

腾讯交互翻译
腾讯交互翻译

腾讯AI Lab发布的一款AI辅助翻译产品

下载
  • sendfile 系统调用:直接在内核空间把文件页缓存中的数据复制到 TCP 发送缓冲区,跳过用户态,实现“零拷贝”(实际是一次内核内拷贝,无用户态参与)
  • splice 系统调用(需配合管道):在支持 pipe 的场景下(如代理中转发响应体),可实现更彻底的零拷贝,数据在内核 buffer 间移动,完全不触碰用户内存
  • Nginx 通过配置 sendfile on;tcp_nopush on; 启用并优化 sendfile 路径

为什么有人误以为 epoll 用了 mmap?

混淆可能源于以下事实:

  • 某些高性能服务器(如部分自研网关)会用 mmap 将大文件映射到进程地址空间,再配合 writevsendfile 使用,但这属于应用层优化,与 epoll 无关
  • Linux 的 epoll 实现内部确实使用了内核内存池和高效数据结构,但这些对用户透明,且不对外暴露 mmap 接口
  • DPDK 或 XDP 等旁路技术会大量使用 mmap 映射网卡 ring buffer,但那是完全绕过内核协议栈的方案,Nginx 默认不使用

Nginx 实际的数据路径优化要点

要真正降低拷贝开销,关键不在 epoll,而在请求类型和配置协同:

  • 静态文件服务:启用 sendfile on; + tcp_nopush on;,让内核完成文件到 socket 的搬运
  • 反向代理响应转发:Nginx 1.17.6+ 支持 proxy_buffering off; 配合 splice(需内核支持),实现响应体零拷贝中转
  • 避免大 body 读取:用 client_max_body_size 限制上传,防止 Nginx 将整个请求体读入用户态内存
  • 利用内核 TCP 缓冲区:合理设置 net.ipv4.tcp_wmemnet.ipv4.tcp_rmem,减少分段与重传带来的额外拷贝

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

693

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3618

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

54

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

72

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号