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

相关推荐
a里啊里啊13 小时前
Redis面试题记录
数据库·redis·缓存
杰克尼14 小时前
redis(day03-优惠券秒杀)
数据库·redis·缓存
刘~浪地球18 小时前
数据库与缓存--MySQL 高可用架构设计
数据库·mysql·缓存
小兜全糖(xdqt)18 小时前
Ubuntu22.04安装最新版本redis
数据库·redis·缓存
大卡片21 小时前
IO缓存区
linux·运维·缓存
不知名的老吴1 天前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
杰克尼1 天前
redis(day03-商户查询缓存)
数据库·redis·缓存
刘~浪地球1 天前
Redis 从入门到精通(十三):哨兵与集群
数据库·redis·缓存
一个有温度的技术博主1 天前
Lua语法详解:从变量声明到循环遍历的避坑指南
redis·缓存·lua
一个有温度的技术博主2 天前
深入多级缓存:JVM进程缓存实战与数据库表拆分策略
jvm·数据库·缓存