oracle怎么样实现数据库跨机房同步?
一、oracle怎么样实现数据库跨机房同步
除了使用第三方工具,Oracle提供了extended cluster可以实现类似的功能,使用Oracle RAC + ASM。简单说下这个。
1. 两边的主机需要同时访问到两边的存储。
2. 创建normal redundancy 的diskgroup,把来自两个存储的磁盘分别放入两个failuregroup中。这样,来自一个存储的数据镜像一定存在另外一个存储中。
3. 分别在两边的ASM实例上设置参数ASM_PREFFERED_READ_FAILURE_GROUPS,指向本地的failure group。
4. 针对存放voting file和ocr的diskgroup,需要3个failure group的。因此,除了把两个failure group分别存放在两个存储上,需要再建一个quorum failure group在第三个位置,nfs即可。空间不用很大,因为quorum只存voting file,仲裁时才会被使用。
实际工作原理:
1. 两边的实例访问同一个数据库,所有数据块在本地存储有完整的一份。
2. 读操作只发生在本地存储。
3. 写操作需要本地和远端全部完成才返回。
4. 任何一边完全down掉,都不会影响另一边。
所以,如果你的存储网络够快,针对写操作不是很频繁的系统,还是行得通的,是个选择。
另外,应用需要很好的规划,较好从两个节点分别访问不同的数据集合,尽量减少cache fusion。 微调一些参数,比如可以更好利用read mostly等特性,减少网络传输。
国外的应用相对多一点。国内很少见,具体效果,有待考证。
延伸阅读:
二、什么是数据库和数据库管理系统
数据库的应用非常广泛,举个例子,我们平时在浏览器上搜索内容,就要用到数据库去检索我们的关键字。以前我们可能会用数组、集合、文件等来存储数据,但是接下来我们就会面临一个问题,当存储的数据或内容过多的时候,我们如何去精准的找到我们需要的东西,这时候数据库管理系统就派上了用场。除此之外,数据库管理系统还能永久的储存我们的数据。
为了便于大家理解,这里先给大家讲解几个概念
DB数据库(database):存储数据的“仓库”。它保存了一系列有组织的数据。
DBMS数据库管理系统(Database Management System):数据库是通过DBMS创建和操作的容器。
猜你喜欢LIKE
相关推荐HOT
更多>>MySQL索引为什么能让查询效率提高?
一、MySQL索引为什么能让查询效率提高DB在执行一条Sql语句的时候,默认的方式是根据搜索条件进行全表扫描。如果我们对某一字段增加索引,查询时...详情>>
2023-10-19 13:16:01什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
一、四层负载均衡(L4 proxy)四层负载均衡工作在OSI模型的传输层,由于在传输层,只有TCP/UDP协议,这两种协议中除了包含源IP、目标IP以外,还包...详情>>
2023-10-19 09:17:45为什么用navicat连接sqlserver后看不到master数据库?
一、为什么用navicat连接sqlserver后看不到master数据库在navicat的安装目录下找到sqlserver的驱动双击安装即可,现在我们就可以连接Navicat了...详情>>
2023-10-19 08:23:06mq消息积压中,突然mq挂了,或者mysql挂了,或者两个都挂了怎么处理?
一、mq消息积压中,mq挂了的处理方法如果MQ挂掉,势必会影响发消息的逻辑,MQ不像数据库,挂了就没办法进行任何操作了。MQ本身就是用于多系统解...详情>>
2023-10-19 06:18:33热门推荐
Python语言除了爬虫scrapy外还有哪些优势?
沸MySQL分布式集群数据是怎么存储的?
热MySQL索引为什么能让查询效率提高?
热oracle怎么样实现数据库跨机房同步?
新安卓开发前需要考虑哪些问题?
怎样系统全面的分析oracle的AWR报告?
IS(信息系统)没有数据库,系统的数据如何存储?
开发APP软件需要哪些编程语言和开发环境?
互联网、金融这两个领域上用于数据挖掘、数据分析的数据库是什么?
一个搜索框对应数据库多个字段,后台怎么对应?
什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
用count(*)做判断条件怎么弄的好一点?
为什么用navicat连接sqlserver后看不到master数据库?
MySQL的select语句怎么输出多行常量?