大话oraclerac集群、高可用性、备份与恢复_Oracle RAC结构

Oracle RAC结构

Oracle真正集群的出现是在Oracle公司收购Rdb并吸收了相关技术优势后,才正在推出了属于自己的RAC集群解决方案。RAC​和集群分类章节提到的集群系统有很多相似之处,从下图我们大概了解一下RAC集群的层次结构和所需的软硬件环境。

b49c2f5ed050cbce3d5e4863c96bd990.png

Oracle Rac 结构

从上图可以看出,RAC集群是由若干个物理计算机组成( 每个叫作一个节点),这些节点间通过网线(心跳线)连接。每个节点上都运行一个Oracle实例(Instance), 这些实例通过一个集群管理软件(Clusterware, 集群件)的协助,共同操作一个数据库。从用户(使用者)的视角来看,他们看到的只是一个数据库。

我们从逻辑上可以把RAC集群分为存储层、网络层、集群件层、应用层4层结构,下面我们逐一讲解一下各分层的概念。

存储层

Oracle RAC其实是一个多实例、单数据库的系统。其中数据文件、联机日志、控制文件等文件在集群中只有一份。集群当中不管有多少个节点,这些节点都平等地使用着同样的数据文件,每个节点服务器通过光纤线连接到存储上。虽然RAC中有多个实例,但是只有一个数据库,这个数据库就保存在共享存储的磁盘上。

在Oracle中,实例和数据库这两个概念是不同的。实例特指由SGA内存结构和后台进程组成的运行时环境,因此Oracle实例是一个动态的概念,而数据库指的是数据文件、控制文件、日志文件这些保存在存储上的永久文件,是一个静态的概念。

因此,Oracle的实例和数据库是多对一的关系,在单实例环境中,二者是一对一的关系,所以二者经常会混淆使用,会被认为是同一个概念。但是在RAC集群环境中,可以有多个实例,但是数据库就只有一个,所以区分这两个概念有重要意义。

网络层

通过上图的RAC的结构图,我们可以发现在整个RAC集群环境中,是有3个网络存在的。一个是访问者访问数据库时,提供的一个公共网络,主要用于提供数据库查询和操作等服务;另一个是由私有网卡组成的私有网络,用于RAC集群各个节点间的互联,既是心跳线;第三个是各个节点和存储设备进行连接的存储网络。

集群键层

Oracle在单机环境下是运行在OS操作系统的内核之上的,操作系统负责和硬件设备进行交互,并通过访问接口。Oracle系统是不会直接操作硬件的,而是有操作系统替代完成的。

但是,到了RAC集群环境下,虽然会有多个实例(节点或计算机),但是Oracle的存储设备是共享的。这个时候如果还依赖OS操作系统,只能控制单机上的多个进程间的访问,无法实现多个节点间的协调工作。因此,Oracle RAC引进额外的控制机制,这个机制就是位于Oracle和OS操作系统之间的多了一集群管理软件(Clusterware),它会在OS操作系统之前截获请求,然后和其他节上的Clusterware协商,最终完上层的请求。

应用层

Oracle RAC应用层,必须要提到一个软件CRS,CRS是Oracle Cluster Ready Service(Oracle集群就绪服务)。CRS是Oracle 10gR2开始的,用以提供标准的群集服务接口,用来搭建一般应用程序的高可用集群。之后从Oracle 10.2版本开始把CRS改名为上面的Oracle Clusterware。并且这个产品不局限于搭建Oracle数据库的集群,其它软件可以借助其API搭建集群功能。

集群环境之所以能够提供高可用性,是因为集群软件(CRS)对运行于其上的应用进行监视,并在发生异常时进行重启、切换等干预手段,这些被CRS监控的对象就叫作CRS Resource。可以简单的理解,CRS Resource通常是一个进程或者有一组进程组成的服务。通过这些服务提供应用。

其中,RAC集群的CRS Resource主要有GSD ( Global Service Daemon)、ONS (Oracle Notification Service Daemon)、VIP、 Database、 Instance、 Listener 和Service。

总结:

本节主要大概介绍Oracle RAC的结构和逻辑层次,主要目的为了读者可以对Oracle RAC集群有一个宏观的了解。

Oracle教程_Oracle在线学习教程_FREE教程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/340169.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java obix_obix协议在java中的配置和使用详解

前言本文主要给大家介绍的是关于obix协议在java中的配置和使用,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。什么是 oBIX?简单来讲,obix是一种 XML 通讯协议,使用Http Request/Post方式进行数据通…

java7和java8切换_仍不切换到Java 8的6个理由

java7和java8切换Java 8很棒。 期。 但是……在我们有机会玩耍并玩弄它之后,就该退出了,避免吃盐。 所有的好东西都是有代价的,在这篇文章中,我将分享Java 8的主要痛点。请确保在升级和释放7之前您已经意识到了这些痛点。 1.并行…

python求阶乘之和_python计算阶乘前n项和

广告关闭 腾讯云11.11云上盛惠 ,精选热门产品助力上云,云服务器首年88元起,买的越多返的越多,最高返5000元! 知道公式后就很简单了,利用for循环,第几行i1就等于几,当然python中是没有…

您需要了解的有关UI测试的所有信息

让我们从一个问题开始。 用户在网站上进行互动的第一件事是什么? 接口,当然。 网站的外观是在用户身上产生“第一印象”的第一件事。 交互式Web应用程序可以为用户带来成败,这就是为什么越来越多的人选择对其Web应用程序进行UI测试的原因。 …

python docx库使用样例_Python docx库用法示例分析

本文实例分析了Python docx库用法。分享给大家供大家参考,具体如下: 打开及保存文件: from docx import Document document Document(test.docx) document.save(test.docx) 添加文本: document.add_paragraph(test text) 调整文本…

使用java理解程序逻辑试卷_《使用Java理解程序逻辑》试题分析

1、在Java中,一下方法属于String类的有()A:insert(int offset,char [] c);B:replace(int start,int end String str);C:split(String regex);D:endsWith(String suffix);正确答案:C、D解析:A&am…

python合并word单元格_python之DataFrame实现excel合并单元格_python

这篇文章主要为大家详细介绍了python之DataFrame实现excel合并单元格,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 在工作中经常遇到需要将数据输出到excel,且需要对其中一些单元格进行合并,比如如下表表格,需要…

java做服务器端给客户端传数据包_java 服务器怎样给客户端传输数据

展开全部服务器端源码:import java.io.BufferedReader;import java.io.File;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.net.Se…

pooled-jms_Hibernate隐藏的宝石:pooled-lo优化器

pooled-jms介绍 在这篇文章中,我们将揭示一个序列标识符生成器,​​它结合了标识符分配效率和与其他外部系统的互操作性(同时访问底层数据库系统)。 传统上,有两种序列标识符策略可供选择。 序列标识符,对…

apache geode项目结构_Apache Flink-基于Java项目模板创建Flink应用(流计算和批计算)...

Apache Flink创建模板项目有2种方式:1. 通过Maven archetype命令创建;2. 通过Flink 提供的Quickstart shell脚本创建;关于Apache Flink的环境搭建,请参考相关链接:Apache Flink快速入门-基本架构、核心概念和运行流程A…

使用UriBuilder快速创建URI

如果您有权访问JAX-RS API和项目中的实现(很多这样做),则可以使用JAX-RS的UriBuilder通过使用可解析占位符的构建器模式方便地创建URI。 看下面的例子: String host System.getProperty( "host" , "localhost&qu…

python中列表和元组的相同点和不同点_详解Python语言中元组和列表的区别

本篇介绍Python中的元组数据类型,文中会讨论元组与列表的区别,元组的声明、赋值及其相关运算。通过本篇的学习,可以达成如下目标。 ● 掌握元组和列表的区别 ● 掌握元组的声明和赋值 ● 掌握适用于元组的相关运算 Python元组和Python列表数据…

mysql的复制订阅_如何删除发布与复制订阅数据库 'distribuion' 的方法

之前因为从VFP数据库中把数据导入到SQL SERVER2000中,用DTS做了发布与复制数据库distribution ,现在要把它删除,当在企业管理器中执行删除时,提示下面的错误:Error 3724: cannot drop the database distribution becau…

matlabif语句怎么用_公益心 码客行(2)—— 简单语句

回顾与反思&#xff1a;cout语句的用法关于第一课的思考与实践问题&#xff0c;有答案了吗——请写出这个程序的输出结果。#include using namespace std;int main(){cout<<1<cout<<12<return 0;}提示&#xff1a;输出结果如下。13即&#xff1a;输出项为数值…

java 多线程 聊天_Java做一个多线程类似于QQ的聊天程序。

展开全部//时间关系,粗略的做了一下,一个模拟UDP协议的测试,图标,IP,以及端口都可以设成//发送者端的电脑参数32313133353236313431303231363533e78988e69d8331333366306533!import java.awt.BorderLayout;import java.awt.Color;import java.awt.GridLayout;import java.awt.e…

组织机构代码输入测试用例_测试代码以用于过大的输入

组织机构代码输入测试用例在编写单元测试时&#xff0c;我们主要关注业务的正确性。 我们将竭尽所能&#xff0c;开开心心地走在最前沿。 我们有时会进行微基准测试并衡量吞吐量。 但是经常遗漏的一个方面是当输入过大时我们的代码如何表现&#xff1f; 我们测试了如何处理正常…

python子进程关闭fd_python – 捕获崩溃的子进程的“分段错误”...

shell可能会生成“Segmentation fault”消息.要找出该过程是否被SIGSEGV杀死,请检查proc.returncode -signal.SIGSEGV.如果要查看消息,可以在shell中运行该命令&#xff1a;#!/usr/bin/env pythonfrom subprocess import Popen, PIPEproc Popen(shell_command, shellTrue, st…

layui 分页 固定底部_论layui的使用体验

layui这个东西有收费跟免费版本&#xff0c;当然我在工作当中用的是免费的版本。至于说我为什么要用这个东西了&#xff1f;原因是这样的&#xff0c;当时我们用的是datatables&#xff0c;由于前期工作上没有相关的需求说是要什么表格相关列固定啊&#xff0c;自动统计啊&…

巴特沃斯滤波器python_如何用Scipy.signal.bu实现带通巴特沃斯滤波器

您可以跳过button的使用&#xff0c;而只需为过滤器选择一个顺序&#xff0c;看看它是否符合您的过滤条件。要生成带通滤波器的滤波器系数&#xff0c;请将滤波器阶数、截止频率Wn[low, high]&#xff08;表示为奈奎斯特频率的分数&#xff0c;即采样频率的一半&#xff09;和频…

章鱼扫描仪:Java构建工具和恶意软件

Alvaro Munoz最近在GitHub Security Lab网站上发布了“ Octopus扫描程序恶意软件&#xff1a;攻击开源供应链 ”。 我发现这篇文章很有趣&#xff0c;原因有很多&#xff0c;其中包括对Octopus Scanner恶意软件如何工作以及如何被发现&#xff0c; GitHub安全事件报告团队 &…