多处理器一致协议(MSI)协议详细介绍

多处理器一致协议 MSI 协议详细介绍


读操作 写操作 命中-共享S 命中-已修改M 未命中 命中-共享S 命中-已修改M 未命中 其他缓存响应 其他缓存响应 内存或其他缓存响应 开始 缓存行请求 检查本地缓存 检查本地缓存 直接读取 直接读取 发起总线读BusRd 广播无效化Inv, 更新为M 直接写入 发起总线读BusRd 更新本地缓存为S或M 更新本地缓存为I 更新本地缓存为M 结束

什么是 MSI 协议?

MSI(Modified, Shared, Invalid)协议是一种缓存一致性协议,用于在多处理器系统中维护缓存数据的一致性。它通过定义缓存行(cache line)的三种状态来实现这一目标:Modified(已修改)、Shared(共享)和Invalid(无效)。

MSI 协议的状态

MSI协议中,缓存行可以处于以下三种状态之一:

  1. Modified (M) 状态:表示缓存行中的数据已被修改,并且是最新的,其他缓存中没有该数据的副本。
  2. Shared (S) 状态:表示缓存行中的数据是干净的,与内存中的数据一致,并且可能被多个缓存共享。
  3. Invalid (I) 状态:表示缓存行中的数据是无效的,需要从内存或其他缓存中获取最新数据。

MSI 协议的工作原理

MSI协议通过监听总线上的事务来维护缓存一致性。当处理器执行读或写操作时,会根据缓存行的状态和其他处理器的监听响应来更新缓存状态。

  • 处理器读(Read):如果缓存行处于Shared状态,则可以直接读取;如果是Modified状态,可以直接读取且不影响其他缓存;如果是Invalid状态,则需要从内存或其他缓存中读取数据,并更新状态为Shared。
  • 处理器写(Write):如果缓存行处于Modified状态,可以直接写入;如果是Shared状态,则需要先将其他缓存中的相应缓存行置为Invalid,然后再写入;如果是Invalid状态,则需要先从内存中读取数据,然后写入并更新状态为Modified。
  • 总线读(BusRd):当缓存行缺失时,会触发总线读操作,其他处理器需要响应并可能需要更新缓存状态。
  • 总线互斥读(BusRdX):当一个处理器需要独占访问缓存行时,会触发总线互斥读操作,其他处理器需要将相应的缓存行置为Invalid。

MSI 协议的流程

  1. 缓存行请求:当处理器请求一个缓存行时,会检查本地缓存中的状态。
  2. 状态转换:根据请求的类型(读或写)和缓存行的当前状态,处理器会更新缓存行的状态。
  3. 总线事务:如果需要,处理器会发起总线事务,如BusRd或BusRdX,以获取数据或通知其他处理器状态变更。
  4. 响应处理:其他处理器监听总线事务,并根据事务类型和自己的缓存行状态做出响应,可能包括更新自己的缓存行状态或提供数据。

MSI 协议的应用场景

MSI协议适用于那些需要保持缓存一致性的多处理器系统,尤其是在小规模系统中,因为它依赖于总线来广播一致性消息。这种协议简单而有效,但当多个缓存共享同一数据块时,可能会因为多次无效化操作而增加流量负载。

MSI 协议的优势与不足

  • 优势
    • MSI协议通过状态标识和总线事务来有序地维护数据块状态,确保了数据块状态的清晰和一致性。
    • 它可以使用总线或环形网作为一致性事务的广播介质,且硬件实现的MSI协议在功能和可靠性上较为健壮。
  • 不足
    • MSI协议在多个私有缓存中都含有同一个共享数据块时,会进行多次写作废操作,增加流量负载。
    • 总线的带宽有限,扩展性差,且总线上的消息对于一些处理器核来说是不需要的,影响了总线的有效利用率。
相关推荐
weixin_462428473 小时前
使用 Caffeine 缓存并在业务方法上通过注解实现每3到5秒更新缓存
java·缓存
Daniel 大东4 小时前
idea 解决缓存损坏问题
java·缓存·intellij-idea
起飞的风筝5 小时前
【redis】—— 环境搭建教程
数据库·redis·缓存
古人诚不我欺7 小时前
Redis设置密码认证,以及不重启服务情况下设置临时密码
数据库·redis·缓存
ktkiko111 天前
Redis中的缓存设计
数据库·redis·缓存
激流丶1 天前
【缓存策略】你知道 Write Around(缓存绕过写)这个缓存策略吗?
java·分布式·缓存
激流丶1 天前
【缓存策略】你知道 Write Through(直写)这个缓存策略吗?
java·分布式·后端·缓存·中间件
ascarl20101 天前
系统启动时将自动加载环境变量,并后台启动 MinIO、Nacos 和 Redis 服务
数据库·redis·缓存
LightOfNight1 天前
Redis设计与实现第9章 -- 数据库 总结(键空间 过期策略 过期键的影响)
数据库·redis·后端·缓存·中间件·架构
_.Switch1 天前
Python 自动化运维持续优化与性能调优
运维·开发语言·python·缓存·自动化·运维开发