美文网首页
总线锁、缓存锁

总线锁、缓存锁

作者: lenny611 | 来源:发表于2019-08-14 23:21 被阅读0次

操作系统必须要有一些机制和原语,以保证某些基本操作的原子性的两种机制:
1.总线锁定
2.缓存一致性

总线锁定:
现在的CPU一般都有自己的内部缓存,根据一些规则将内存中的数据读取到内部缓存中来,以加快频繁读取的速度。现在服务器通常是多 CPU,更普遍的是,每块CPU里有多个内核,而每个内核都维护了自己的缓存,那么这时候多线程并发就会存在缓存不一致性,这会导致严重问题。


CPU和缓存图.png

操作系统提供了总线锁定的机制。前端总线(也叫CPU总线)是所有CPU与芯片组连接的主干道,负责CPU与外界所有部件的通信,包括高速缓存、内存、北桥,其控制总线向各个部件发送控制信号、通过地址总线发送地址信号指定其要访问的部件、通过数据总线双向传输。在CPU1要操作共享变量的时候,其在总线上发出一个LOCK#信号,其他处理器就不能操作缓存了该共享变量内存地址的缓存,也就是阻塞了其他CPU,使该处理器可以独享此共享内存。
总线锁定把CPU和内存的通信给锁住了,使得在锁定期间,其他处理器不能操作其他内存地址的数据,从而开销较大。

缓存一致性:
与volatile的原理一致,也是通过拷贝,侦测共享变量的值,当发现共享变量改变时,重新读取。

相关文章

  • CAS锁了总线或者缓存行还是volatile锁了总线或者缓存行

    CAS锁了总线或者缓存行还是volatile锁了总线或者缓存行? CAS全称Compare And Set(或Co...

  • 总线锁、缓存锁

    操作系统必须要有一些机制和原语,以保证某些基本操作的原子性的两种机制:1.总线锁定2.缓存一致性 总线锁定:现在的...

  • 多线程之Volatile笔记

    cpu的高速缓存架构 待补充 多核cpu下如何保证数据的安全性 总线锁、#LOCK前缀指令加上缓存锁(MESI协议...

  • 原子操作的实现原理

    1. 处理器如何实现原子操作 1.1 使用总线锁 1.2 使用缓存锁 2. Java如何实现原子操作 2.1 偏向...

  • java多线程-3-volatile

    缓存一致性问题 起因:高速缓存 方案总线LOCK#锁,释放锁前该块内存无法被别的cpu或线程访问缓存一致性协议(I...

  • 基于缓存或zookeeper的分布式锁实现

    阅读目录 缓存锁 zookeeper 锁 比较 回到顶部 缓存锁 我们常常将缓存作为分布式锁的解决方案,但是却不能...

  • 4:Redis 分布式锁 (文末有项目连接)

    1:什么是缓存分布式锁 2:分布式锁的关键代码 3:业务代码使用分布式缓存锁 4:业务代码使用分布式缓存锁 5:测...

  • MySql高效应用(1)

    客户端 -->解析优化-->缓存-->存储引擎 并发控制 1、串行(队列)执行2、读(共享锁) 写(排他锁)锁 锁...

  • 技术好文集合

    缓存热点key 大value问题,解决方案 golang sync.Map 如何理解互斥锁、条件锁、读写锁以及自旋锁?

  • mysql 锁

    锁 1.1 排他锁X共享锁S 意向排他锁意向共享锁 一致性非锁读操作MVCC 会把访问的row读缓存起来。read...

网友评论

      本文标题:总线锁、缓存锁

      本文链接:https://www.haomeiwen.com/subject/ewmojctx.html