cache coloring 缓存着色

cache coloring虽然实现起来很复杂,但其原理很简单。 下面我用几句话简单说明cache coloring的原理:

  • 颜色(color)是物理 page 的颜色。
  • 缓存一个page需要使用一些连续的set,这些set的集合叫做 cache bin。 使用相同 cache bin 的 pages 具有相同的颜色。
  • 物理地址 bits[y-1:12] 值相同的所有 page 具有相同的 color 。(为什么是12,因为假设使用4KB page)
  • 物理地址的 bits[y-1:12] 也叫做 color bits 或 cache bin bits 。
  • 至此,我们可知,系统中全部的物理内存页就都有了颜色。
  • Hypervisor为VM分配物理内存页时,每个VM使用不同颜色的物理内存,就可以避免VM之间互相踩踏对方的cache。(因为不同颜色的物理内存页的cache一定在不同的set中。)
  • OS在为进程分配物理内存页时,每个进程使用不同颜色的物理内存,可以避免进程之间互相踩踏对方的cache。

关于cache的基本概念参考上一篇https://blog.csdn.net/power1952/article/details/136472919

相关推荐
@海~涛20 小时前
AOSP源码下载与编译
android·数据库·缓存·安卓·安全架构
galaxyffang21 小时前
Redis 的 16 个数据库应用场景
数据库·redis·缓存
源远流长jerry21 小时前
DNS解析过程以及CDN流程
http·缓存
记得开心一点嘛1 天前
布隆过滤器解决缓存穿透
redis·缓存
源远流长jerry1 天前
浏览器的条件请求以及缓存
缓存
小北方城市网1 天前
第 6 课:全栈项目性能 & 安全双进阶 ——Redis 缓存 + JWT 认证(打造高并发高安全后端)
开发语言·数据库·redis·python·安全·缓存·数据库架构
gjc5921 天前
数据库和缓存稳定性保障-扩容及升级规范
java·开发语言·数据库·缓存
什么都不会的Tristan1 天前
解决缓存相关问题(缓存穿透、缓存雪崩、缓存击穿)
缓存
rchmin2 天前
Redis BitMap介绍及使用场景示例
数据库·redis·缓存
Go高并发架构_王工2 天前
Redis未来展望:Redis 7.0新特性与技术发展趋势
数据库·redis·缓存