基于CPU缓存的进程绑定研究
发布时间:2017-09-01 19:30
本文关键词:基于CPU缓存的进程绑定研究
【摘要】:在过去的20多年中,CPU的处理速度和内存的访问速度差距越来越大,处理器的性能以每年大约55%速度快速提升,而内存性能的提升速度则只有每年10%左右,形成了所谓“存储墙”现象。不均衡的发展速度造成了当前内存的存取速度严重滞后于处理器的计算速度,内存瓶颈对日益增长的高性能计算形成了极大的制约。但缓存技术的出现极大的缓解了这一现象,而对缓存的优化也成为了近几年的研究热点之一。随着多核技术的发展,多个处理器对有限的末级缓存空间的竞争造成的缓存“抖动”现象严重的影响了缓存的效率。而造成缓存“抖动”现象的实质是进程间的干扰,缓存替换算法不会对缓存中所存储的数据块的对应进程有感知,造成缓存内关键的数据块的重复替换。并且由于上级缓存对数据的过滤,造成了LRU替换算法在末级缓存上的效率不高。所以,提出一个效率更高的缓存替换策略是优化缓存最直接的方案之一。针对LRU作为末级缓存替换算法由于线程间的干扰造成缓存抖动而降低缓存效率的现象,本文提出了基于进程绑定的IBP替换算法,通过将进程与缓存进行绑定,使得缓存对所存储的数据块的对应进程有所感知,在进行数据块替换时会根据其绑定状态及其它关键参数选用不同的替换策略。进程绑定在一定程度上避免了缓存中数据块的干扰,粗粒度的从替换算法的角度实现了对缓存空间的划分,对关键数据块进行了保护,缓解了末级缓存中的缓存“抖动”现象,提高了缓存的效率。最后本文通过实验表明在相同运行环境下,运行多组不同负载,IBP替换算法相较于传统的LRU替换算法的运行时间减少了7%左右,并且随着核数的增加对缓存效率的提升也更加明显。这一结论也为未来对缓存优化进行更深入的研究奠定了理论基础。
【关键词】:存储墙 缓存抖动 进程绑定 IBP替换策略
【学位授予单位】:北京工业大学
【学位级别】:硕士
【学位授予年份】:2016
【分类号】:TP333
【目录】:
- 摘要4-5
- Abstract5-8
- 第1章 绪论8-14
- 1.1 课题背景8-9
- 1.2 国内外研究现状9-11
- 1.3 论文的主要工作11-12
- 1.4 论文的组织结构12-14
- 第2章 CPU缓存机制研究现状14-26
- 2.1 缓存原理及关键技术14-15
- 2.2 地址映射15-19
- 2.2.1 全相连映射15-16
- 2.2.2 直相连映射16-18
- 2.2.3 组相连映射18-19
- 2.3 数据一致性19-20
- 2.4 缓存层次划分20-22
- 2.4.1 按路划分20-21
- 2.4.2 按页划分21-22
- 2.5 缓存替换策略22-24
- 2.5.1 经典缓存替换算法22-24
- 2.6 本章小结24-26
- 第3章 CPU缓存机制优化及GEM5实现架构26-36
- 3.1 CPU缓存替换策略优化26-31
- 3.1.1 基于最近使用时间的缓存替换算法26-27
- 3.1.2 基于使用频率的缓存替换算法27-29
- 3.1.3 基于LRU的替换策略29-31
- 3.2 其他CPU缓存优化策略31-32
- 3.3 基于进程绑定的IBP缓存替换算法32-33
- 3.4 Gem5实现架构33-34
- 3.4.1 Gem5全系统模拟架构33-34
- 3.4.2 Gem5模拟平台仿真模型34
- 3.5 本章小结34-36
- 第4章 基于进程绑定的IBP替换算法设计36-46
- 4.1 问题概述36
- 4.2 LRU替换算法的不足36-39
- 4.2.1 末级缓存的抖动现象36-38
- 4.2.2 LRU的不公平性38-39
- 4.3 基于进程绑定的IBP替换算法设计39-45
- 4.3.1 进程绑定方案设计39-40
- 4.3.2 IBP替换算法设计40-45
- 4.4 本章小结45-46
- 第5章 基于进程绑定的IBP替换算法实现46-62
- 5.1 进程绑定实现46-47
- 5.2 IBP替换算法实现47-52
- 5.2.1 IBP替换算法模块的建立47-49
- 5.2.2 IBP替换算法的实现49-52
- 5.3 实验环境52-54
- 5.3.1 负载组成53-54
- 5.4 实验方案54-55
- 5.5 实验结果及分析55-61
- 5.6 本章小结61-62
- 结论62-64
- 参考文献64-70
- 攻读硕士学位期间所发表的学术成果70-72
- 致谢72
本文编号:773990
本文链接:https://www.wllwen.com/kejilunwen/jisuanjikexuelunwen/773990.html