《现代体系结构上的UNIX系统:内核程序员的对称多处理和缓存技术(修订版)》——2.8 高速缓存冲洗

简介: 所有的高速缓存实现都为操作系统提供了从高速缓存中删除数据的能力,这种功能一般称为高速缓存冲洗(cache flushing)。根据高速缓存组织结构的不同,这对于防止意外引用过时数据、保持高速缓存一致性来说可能是必不可少的功能(高速缓存一致性在多处理器系统上有更广泛的含义,这将在第三部分讨论)。

本节书摘来自异步社区《现代体系结构上的UNIX系统:内核程序员的对称多处理和缓存技术(修订版)》一书中的第2章,第2.8节,作者:【美】Curt Schimmel著,更多章节内容可以访问云栖社区“异步社区”公众号查看

2.8 高速缓存冲洗

所有的高速缓存实现都为操作系统提供了从高速缓存中删除数据的能力,这种功能一般称为高速缓存冲洗(cache flushing)。根据高速缓存组织结构的不同,这对于防止意外引用过时数据、保持高速缓存一致性来说可能是必不可少的功能(高速缓存一致性在多处理器系统上有更广泛的含义,这将在第三部分讨论)。一个高速缓存需要冲洗的准确时机则取决于它的组织结构,这是接下来的几章要讨论的主题。高速缓存冲洗有两种形式:使主存储器有效(validating main memory)和使高速缓存无效(invalidating cache)。

使主存储器有效的形式是指在采用写回策略的高速缓存中将修改过的数据写回到主存储器内的做法。正如2.2.5节所讨论的那样,这是由高速缓存在替换一个修改过的行期间自动完成的,但是它也可以由操作系统明确地进行控制。一次显式的使有效操作(validation operation)将把行内的数据写入主存储器,然后将高速缓存内数据的修改位关闭(因为相对于主存储系统内的副本而言不再是修改过的了)。使主存储器有效的方法还可以让操作系统随时更新主存储器到最新。这可以防止主存储器内数据的过时副本被系统中不使用高速缓存的其他部分所引用。如果操作系统指定将一个高速缓存行写回主存储器,而这一行要么不在高速缓存中,要么当前并没有被修改过,那么这个使有效操作对高速缓存什么也不做。这种类型的缓存冲洗从不需要在采用写直通策略的高速缓存上进行,因为存储器始终和高速缓存中的内容保持同步。

使高速缓存无效的形式是指,如果高速缓存中的数据被修改过,那么无需先将它写回主存储器就把它丢弃的做法。这种功能既可以用于写直通高速缓存,也可以用于写回高速缓存。操作系统使用它来丢弃高速缓存中的过时数据。如果数据在主存储器中的副本的更新与高速缓存无关,从而导致被缓存的数据副本过时,就会需要这种操作。让该数据在高速缓存中无效会造成下一次引用该数据时出现一次缺失,因此要从主存储器中重新读取该数据的正确副本。

一般而言,采用写回策略的高速缓存允许将独立的使主存储器有效和使高速缓存无效操作组合成单个操作,因为它们是一种常用的序列。在这种情况下,如果高速缓存中出现了该行,而且被修改过,那么就首先完成主存储器有效操作,于是该数据就不会丢失。在此之后往往会跟着进行一次使高速缓存无效操作。

两种高速缓存冲洗形式中的任何一种通常都能够以单行为基础来使用。大多数实现允许操作系统指定要被冲洗的数据的地址。随后在高速缓存中查找这个地址,如果命中则被冲洗掉。如果没有命中,则保持高速缓存不变。MIPS处理器就是以这种方式工作的。有些实现可以允许一次冲洗一组地址,例如一页甚至整个高速缓存。TI MicroSPARC和SuperSPARC就允许后一种方式,它们称之为“洗净”功能。Motorola 68040和88200支持一次按行、按页面或者整个高速缓存的冲洗。

相关文章
|
1天前
|
数据采集 存储 缓存
如何使用缓存技术提升Python爬虫效率
如何使用缓存技术提升Python爬虫效率
|
5天前
|
存储 缓存 负载均衡
从零到一:分布式缓存技术初探
分布式缓存通过将数据存储在多个节点上,利用负载均衡算法提高访问速度、降低数据库负载并增强系统可用性。常见产品有Redis、Memcached等。其优势包括性能扩展、高可用性、负载均衡和容错性,适用于页面缓存、应用对象缓存、状态缓存、并行处理、事件处理及极限事务处理等多种场景。
20 1
|
2月前
|
存储 缓存 数据库
缓存技术有哪些应用场景呢
【10月更文挑战第19天】缓存技术有哪些应用场景呢
|
2月前
|
存储 缓存 运维
缓存技术有哪些优缺点呢
【10月更文挑战第19天】缓存技术有哪些优缺点呢
|
3月前
|
存储 缓存 NoSQL
解决Redis缓存击穿问题的技术方法
解决Redis缓存击穿问题的技术方法
82 2
|
3月前
|
存储 缓存 Java
在Spring Boot中使用缓存的技术解析
通过利用Spring Boot中的缓存支持,开发者可以轻松地实现高效和可扩展的缓存策略,进而提升应用的性能和用户体验。Spring Boot的声明式缓存抽象和对多种缓存技术的支持,使得集成和使用缓存变得前所未有的简单。无论是在开发新应用还是优化现有应用,合理地使用缓存都是提高性能的有效手段。
50 1
|
4月前
|
缓存 NoSQL Java
SpringBoot的三种缓存技术(Spring Cache、Layering Cache 框架、Alibaba JetCache 框架)
Spring Cache 是 Spring 提供的简易缓存方案,支持本地与 Redis 缓存。通过添加 `spring-boot-starter-data-redis` 和 `spring-boot-starter-cache` 依赖,并使用 `@EnableCaching` 开启缓存功能。JetCache 由阿里开源,功能更丰富,支持多级缓存和异步 API,通过引入 `jetcache-starter-redis` 依赖并配置 YAML 文件启用。Layering Cache 则提供分层缓存机制,需引入 `layering-cache-starter` 依赖并使用特定注解实现缓存逻辑。
1263 1
SpringBoot的三种缓存技术(Spring Cache、Layering Cache 框架、Alibaba JetCache 框架)
|
4月前
|
存储 缓存 NoSQL
【性能飙升的秘密】FastAPI应用如何借助缓存技术实现极速响应?揭秘高效Web开发的制胜法宝!
【8月更文挑战第31天】FastAPI是一个高性能Web框架,利用Starlette和Pydantic实现高效API构建。本文介绍如何通过缓存提升FastAPI应用性能,包括使用`starlette-cache[redis]`实现Redis缓存,以及缓存一致性和缓存策略的注意事项。通过具体示例展示了缓存的配置与应用,帮助开发者构建更高效的Web应用。
297 0
|
5月前
|
存储 缓存 算法
深入了解Memcached:缓存技术的利器
Memcached是一个开源的高性能分布式内存缓存系统,用于加速动态Web应用。它通过将数据库查询结果、API调用结果或其他数据缓存到内存中,减少对数据库的访问频率,从而提高应用的响应速度。本文详细介绍了Memcached的基本原理、架构、安装配置、使用方法、测试方法以及应用场景。通过Memcached,开发者可以有效提升Web应用的性能,减少数据库负载,改善用户体验。
71 5
|
4月前
|
开发框架 Unix Linux
LangChain 构建问题之在Unix/Linux系统上设置OpenAI API密钥如何解决
LangChain 构建问题之在Unix/Linux系统上设置OpenAI API密钥如何解决
60 0