iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >数据库缓存融合分析
  • 617
分享到

数据库缓存融合分析

2024-04-02 19:04:59 617人浏览 薄情痞子
摘要

本篇内容主要讲解“数据库缓存融合分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库缓存融合分析”吧!概念    简单地说,缓存融合就是

本篇内容主要讲解“数据库缓存融合分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习数据库缓存融合分析”吧!

概念

    简单地说,缓存融合就是把oracle RAC数据库中所有数据库缓存作为一个共享的数据库缓存,并被RAC中的所有节点共享。它是实现RAC的基本技术。

    缓存融合主要有如下四个功能:

  (1) 提供扩展性的传输。

  (2) 在实例间传输数据库的映射。

  (3) 跟踪资源的当前位置和状态。

  (4) 在每个实例的SGA的目录结构中保存资源信息。

    图中描述了两节点RAC数据库的运行情况。每个节点都运行一个数据库实例,每个实例包含一组Oracle进程和用于缓存的系统全局区(SGA)。除了这些集群中的每个节点都还运行着一组特殊的进程:全局缓存服务进程(Global Cache Service ,GCS)和全局队列服务进程(Global Enqueue Service,GES),GES主要负责维护字典缓存和库缓存内的一致性,GCS主要负责协调不同实例间对数据块的访问,它们通过Global Resource Directory(GRD)来维护和记录每个数据块的状态,使其在群集中的各个节点之间同步和串行处理对数据的访问。同时,每个数据区块又隶属于某一个节点,对于这个数据区块来说,这个节点称为主节点(Master)。为了在服务器之间均衡工作负载,群集中所有服务器都可以成为部分数据块的主节点,GCS 是oracle 用来实施缓存融合的机制。

缓存融合工作原理

    我们知道,Oracle RAC是采用共享磁盘方式实现数据库的群集。群集环境中所有节点共享且并发地对磁盘上的数据库进行更新,另外还要额外地需要同其它节点进行同步和串行机制,以避免两个或多个节点同时更新同一数据页上的记录,那么Oracle RAC是如何利用缓存融合处理数据同步的?下面通过几种情况模拟分析下缓存的同步原理。

   (1) 节点A读取一个全新的数据块,该数据块没有被任何节点读入

     ①节点A的请求发给GCS,GCS把这个请求转发给这个数据块的主节点,这里假定是节点B。因为这个数据块没有在任何节点的内存中,GCS标记这个数据块状态为S(shared,共享状态),并记录到GRD中。

     ②接着B告诉节点A状态修改了,准备工作都完成了。然后节点A记录共享状态在自己的实例中,并读入该数据块。这时,节点A持有了该数据块,并在GRD中进行记录,标记持有该数据块。此时,整个过程发生了一次io操作。

  (2) 节点C要修改刚才节点A读入的数据块,这里假定节点A刚才读入的数据块SCN是100。

    ①节点C找到该数据块的主节点,也就是节点B,要求能加一个X标记(exclusive,独占状态),表明要修改数据。但是这个数据块可能已经存在于多个节点的实例中,每个实例都有个S标记。

    ②GCS会告诉所有持有该数据块的实例,把状态S标记转换为N标记(null,空状态)。

    ③最后一个从S标记转换为N标记的实例把数据块发送到需要对其进行修改的节点如节点C上。

    ④这时节点C的实例就可以对该数据块加上X标记,并通知该数据块的主节点,也就是节点B的GCS,GCS将最新的标记与位置记录到GRD,并关闭以前节点的资源记录。这时节点C就可以修改该数据块了,假定把SCN从100修改成了101,这个时候磁盘上的数据块SCN还是100,整个过程是通过内部互联进行数据交换,没有磁盘IO产生。

   (3) 节点D也要修改该数据块

    ①与节点C修改该数据块类似,节点D也会找到该数据块的主节点,也就是节点B,要求加一个X(exclusive,独占状态)的,表示要修改该数据块。 

    ②这时GCS会告诉上一次修改成功的节点C,放弃它加上的X标记,因为别的节点也要修改这个数据块。

    ③节点C会确保这个数据块的改变,已经记入联机日志中,然后转换X标记为N标记,并把这个数据块拷贝到节点D。

    ④节点D加上X标记,并通知该数据块的主节点,也就是节点B的GCS,GCS将最新的标记与位置揭露到GRD,并关闭以前节点上的资源记录。这时节点D就可以修改该数据块了,假定把该数据块的SCN从101又修改成102,但是磁盘的数据块上的SCN还是100。可以发现RAC在这个过程中,也没有任何磁盘操作,同样是通过内部互联来完成的。

    (4) 节点A要重新读取该数据块

     ①节点A还是一样,首先找到该数据块的主节点,也就是节点B,希望能读取最新的数据块,也就是SCN为102的内容。

     ②GCS根据GRD得知最新的数据块在节点D上,于是GCS通知节点D。节点D需要确保刚才修改过的数据块已经记录在联机日志中,如果已经确定记录过,则把原来的X标记转换为S标记。

     ③节点D拷贝数据块到节点A的实例,这时节点A获得该数据块,并获得S标记。

     ④最后再告诉该数据块的主节点,也就是节点B,GCS记录最新的标记与位置到GRD,这个时候,节点A与节点D同时持有S标记的相同的数据块,数据块的SCN为102,但是磁盘中的数据块SCN还是100,最后如果发生写操作,只要最新的一个节点发生写操作即可,所以该数据块虽然在不同节点、不同实例中发生了多次改变,最终却只有一次写IO操作。

到此,相信大家对“数据库缓存融合分析”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: 数据库缓存融合分析

本文链接: https://www.lsjlt.com/news/64228.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 数据库缓存融合分析
    本篇内容主要讲解“数据库缓存融合分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库缓存融合分析”吧!概念    简单地说,缓存融合就是...
    99+
    2022-10-18
  • Spring 如何结合Redis数据库实现缓存
    这篇文章将为大家详细讲解有关 Spring 如何结合Redis数据库实现缓存,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1. 依赖包安装pom.xml 加入:<!-- redis c...
    99+
    2023-05-31
    spring redis 缓存
  • 百融榕树利用Spring结合MyBatis实现数据库读写分离
    百融榕树智网AI技术,根据用户个人综合信用情况,为其推荐合适用户的产品和服务。用户登陆榕树界面,每个人能看到的产品信息都是不一样的,包括利率、期限和额度等。相比标准式服务,百融榕树已帮助用户做了筛选,为用户...
    99+
    2022-10-18
  • 大数据存储解决方案中的分离式与超融合部署
    数据中心内部系统的核心要求是 “稳定可靠”,一是指系统在运行过程中有能力提供连续可靠的服务,长时间无故障运行;二是指当故障发生之后,有能力快速定位,及时排查,故障范围不蔓延。 分离式部署的...
    99+
    2022-10-18
  • PHP开发缓存 vs. 数据库缓存:哪个更适合你的网站?
    在Web开发中,缓存是提高网站性能和响应速度的重要手段之一。而在缓存技术中,PHP开发缓存和数据库缓存是常用的两种方式。那么,哪种方式更适合你的网站呢?本文将从原理、优点、缺点和代码示例等方面进行分析比较。一、原理PHP开发缓存PHP开发缓...
    99+
    2023-11-07
    缓存 PHP开发 数据库缓存
  • 【分布式】数据库和缓存双写一致性方案解析
    引言为什么写这篇文章?首先,缓存由于其高并发和高性能的特性,已经在项目中被广泛使用。在读取缓存方面,大家没啥疑问,都是按照下图的流程来进行业务操作。但是在更新缓存方面,对于更新完数据库,是更新缓存呢,还是删除缓存。又或者是先删除缓存,再更新...
    99+
    2023-06-02
  • Redis内存数据库示例分析
    目录redies dict字典Redis的DB实现具体的实现器Redis持久化Aofredies dict字典 这是 Redis 最底层的结构,比如 1个DB 下面有 16个Dict...
    99+
    2022-12-19
    Redis内存数据库 Redis数据库
  • C#实现自由组合本地缓存、分布式缓存和数据查询
    一、背景介绍: 我们在进行数据存储的时候,有时候会加入本地缓存、分布式缓存以及数据库存储三级的结构,当我们取值的时候经常是像下面这样的流程: 1.先取本地缓存,如果值存在直接返回 2...
    99+
    2022-11-13
  • Vuex和前端缓存整合的示例分析
    这篇文章主要介绍了Vuex和前端缓存整合的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。如何存放或更新缓存?缓存数据来源是预知的,我...
    99+
    2022-10-19
  • Redis整合Spring及结合使用缓存的示例分析
    Redis整合Spring及结合使用缓存的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、Redis介绍什么是Red...
    99+
    2022-10-19
  • Redis缓存数据库(一)
    先导知识:Memcache Memcache是一个高性能的分布式内存对象缓存系统,代码类似于Hash。 已经有了Memcache,为什么还要用Redis呢? 下面Memcache的缺点: 不支持数据持久化存储 不支持主从 不支持...
    99+
    2019-11-20
    Redis缓存数据库(一)
  • 分布式之数据库和缓存双写一致性方案解析
    先做一个说明,从理论上来说,给缓存设置过期时间,是保证最终一致性的解决方案。这种方案下,我们可以对存入缓存的数据设置过期时间,所有的写操作以数据库为准,对缓存操作只是尽最大努力即可。也就是说如果数据库写成功...
    99+
    2022-10-18
  • Redis内存数据库分片的示例分析
    这篇文章将为大家详细讲解有关Redis内存数据库分片的示例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 软件下载地址 ·  &...
    99+
    2022-10-19
  • 数据库:分久必合,合久必分
    本篇内容介绍了“数据库:分久必合,合久必分”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!开源、高性能、生态...
    99+
    2022-10-18
  • 数据库存储过程的示例分析
    这篇文章给大家分享的是有关数据库存储过程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 select * from&nb...
    99+
    2022-10-18
  • Oracle数据库部分迁至闪存存储的示例分析
    这篇文章给大家分享的是有关Oracle数据库部分迁至闪存存储的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。环境:Oracle 11.2.0.4 RAC(2 nodes)...
    99+
    2022-10-18
  • 专家解读:利用Angular项目与数据库融合实例
    摘要:面对如何在现有的低版本的框架服务上,运行新版本的前端服务问题,华为云前端推出了一种融合方案,该方案能让独立的Angular项目整体运行在低版本的框架服务上,通过各种适配手段,让Angular项目也能获取到外层框架服务的资源。 ...
    99+
    2021-04-14
    专家解读:利用Angular项目与数据库融合实例
  • 金融数据分析与挖掘具体实现方法 -1
    有人让我写一下关于数据挖掘在金融方面的应用,再加上现在金融对数据方面的要求不断提高,准备用两篇随笔来做个入门总结。 首先,在看这篇随笔以前稍微补充一点金融方面的知识,因为我不是金融专业的,以下补充知识来自互联网与个人整理,欢迎批评指正并补...
    99+
    2023-01-30
    金融 方法 数据
  • PHP redis 缓存数据库(成功)
     PHP redis 缓存数据库(成功)原文:https://www.cnblogs.com/summerGraden/p/13273974.html...
    99+
    2016-11-01
    PHP redis 缓存数据库(成功) 数据库入门 数据库基础教程
  • 阿里云rds数据库 缓存
    阿里云RDS数据库缓存是一种用于优化数据库性能的解决方案。通过在RDS实例上部署缓存,可以将经常访问的数据缓存在内存中,从而提高数据库的读取速度和响应能力。首先,让我们了解一下什么是RDS数据库。RDS (Relational Databa...
    99+
    2023-12-26
    阿里 缓存 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作