基于DPDK的流量动态负载均衡技术研究
摘要 | 第4-5页 |
Abstract | 第5-6页 |
第1章 绪论 | 第10-17页 |
1.1 课题背景和意义 | 第10-11页 |
1.2 国内外研究现状 | 第11-16页 |
1.2.1 负载均衡技术 | 第11-14页 |
1.2.2 数据包处理平台 | 第14页 |
1.2.3 幼多核处理器的技术及发展 | 第14-16页 |
1.3 论文的主要内容 | 第16页 |
1.4 论文的结构安排 | 第16-17页 |
第2章 相关技术 | 第17-32页 |
2.1 多队列网卡技术 | 第17-19页 |
2.1.1 物理网卡多队列 | 第17-18页 |
2.1.2 软件多队列 | 第18-19页 |
2.2 DPDK概述 | 第19-25页 |
2.2.1 UIO技术 | 第20-21页 |
2.2.2 大页内存 | 第21-23页 |
2.2.3 NUM | 第23-24页 |
2.2.4 轮询技术 | 第24页 |
2.2.5 CPU亲和性 | 第24-25页 |
2.3 EAL环境抽象层 | 第25页 |
2.4 DPDK核心组件构成 | 第25-30页 |
2.4.1 内存池(Mempool)组件 | 第26-27页 |
2.4.2 Mbuf库 | 第27-28页 |
2.4.3 Ring队列 | 第28-29页 |
2.4.4 LPM库 | 第29页 |
2.4.5 Hash库 | 第29页 |
2.4.6 内核网络接口库(KNI) | 第29-30页 |
2.5 本章小结 | 第30-32页 |
第3章 基于DPDK负载均衡框架设计与实现 | 第32-46页 |
3.1 整体框架设计 | 第32-36页 |
3.1.1 报文转发框架 | 第32-34页 |
3.1.2 负载均衡框架设计 | 第34-36页 |
3.2 报文转发处理 | 第36-42页 |
3.2.1 收发包流程 | 第37-38页 |
3.2.2 转发算法 | 第38-39页 |
3.2.3 驱动初始化 | 第39-40页 |
3.2.4 内存初始化 | 第40-41页 |
3.2.5 多线程创建 | 第41-42页 |
3.3 逻辑核的通信机制 | 第42-45页 |
3.4 本章小结 | 第45-46页 |
第4章 基于DPDK的动态负载均衡算法设计及实现 | 第46-57页 |
4.1 相关概念 | 第46-50页 |
4.1.1 Toeplitz哈希算法 | 第46-47页 |
4.1.2 RSS以及Symmetric RSS | 第47-50页 |
4.2 基于负载均衡度的参数提取 | 第50-52页 |
4.3 基于负载均衡的多重Hash算法 | 第52-56页 |
4.3.1 算法基本思想 | 第52-55页 |
4.3.2 算法评估指标 | 第55页 |
4.3.3 算法流程 | 第55-56页 |
4.4 本章小结 | 第56-57页 |
第5章 实验验证及效果分析 | 第57-63页 |
5.1 实验环境 | 第57-58页 |
5.2 性能测试 | 第58-59页 |
5.3 功能测试 | 第59-62页 |
5.3.1 RSS与对称RSS效果对比 | 第59-60页 |
5.3.2 动态负载效果测试 | 第60-62页 |
5.4 本章小结 | 第62-63页 |
结论 | 第63-65页 |
参考文献 | 第65-69页 |
攻读学位期间发表的学术论文 | 第69-71页 |
致谢 | 第71页 |