返回顶部
首页 > 资讯 > 数据库 >Oracle RAC的Failover分为哪几种
  • 223
分享到

Oracle RAC的Failover分为哪几种

2024-04-02 19:04:59 223人浏览 独家记忆
摘要

这篇文章主要介绍“oracle RAC的Failover分为哪几种”,在日常操作中,相信很多人在Oracle RAC的Failover分为哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,

这篇文章主要介绍“oracle RAC的Failover分为哪几种”,在日常操作中,相信很多人在Oracle RAC的Failover分为哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle RAC的Failover分为哪几种”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

OracleRAC同时具备HA(HighAvailiablity)和LB(LoadBalance).而其高可用性的基础就是Failover(故障转移).它指集群中任何一个节点的故障都不会影响用户的使用,连接到故障节点的用户会被自动转移到健康节点,从用户感受而言,是感觉不到这种切换。

Oracle10gRAC的Failover可以分为3种:
1.Client-SideConnecttimeFailover
2.TAF
3.Service-SideTAF

注意事项:不能在listener.ora文件中设置GLOBAL_NAME,因为这个参数会禁用Connect-time Failover和Transparent Application Failover.


一.Client-Side Connect Time Failover
Client-Side Connect Time Failover的含义:如果用户端tnsname中配置了多个地址,用户发起连接请求时,会先尝试连接地址表中的第一个地址,如果这个连接尝试失败,则继续尝试使用第二个地址,直至连接成功或者遍历了所有的地址。

这种Failover的特点: 只在建立连接那一时刻起作用,也就是说,这种Failover方式只在发起连接时才会去感知节点故障,如果节点没有反应,则自动尝试地址列表中的下一个地址。一旦连接建立之后,节点出现故障都不会做处理,从客户端的表现就是会话断开了,用户程序必须重新建立连接。


启用这种Failover的方法就是在客户端的tnsnames.ora中添加FAILOVER=ON条目,这个参数默认就是ON,所以即使不添加这个条目,客户端也会获得这种Failover能力。


示例:
RAC=
     (DESCRIPTION=
         (ADDRESS=(PROTOCOL=TCP)(HOST=rac1-vip)(PORT=1521))
        (ADDRESS=(PROTOCOL=TCP)(HOST=rac2-vip)(PORT=1521))
       (LOAD_BALANCE=YES)
     (
        CONNECT_DATA=
   (SERVER=DEDICATED)
       (SERVICE_NAME=RAC)
     )
 )

注:rac1-vip,rac2-vip要添加到hosts文件中,不然可能解析不了。

二.TAF(Transparent Application Failover)

这块的配置,参考:10g & 11g Configuration of TAF(Transparent Application Failover) and Load Balancing [ID 453293.1]

现在的大部分流行的应用系统(如:WEBlogic,Jboss),都是启动时就建立若干到数据库的长连接,在应用程序整个生命周期内重用这些连接。而Client-Side Connet Time Failover的工作方式是它对应用程序的可用性没有太大帮助。

所以从Oracle8.1.5版本只有引入了新的Failover机制—-TAF。所谓TAF,就是连接建立以后,应用系统运行过程中,如果某个实例发生故障,连接到这个实例上的用户会被自动迁移到其他的健康实例上。对于应用程序而言,这个迁移过程是透明的,不需要用户的介入,当然,这种透明要是有引导的,因为用户的未提交事务会回滚。相对与Client-Side Connect Time Failover的用户程序中断,抛出连接错误,用户必须重启应用程序,TAF这种方式在提高HA上有了很大的进步。

TAF的配置也很简单,只需要在客户端的tnsnames.ora中添加FAILOVER_MODE配置项。这个条目有4个子项目需要定义。
1.METHOD:用户定义何时创建到其实例的连接,有BASIC和PRECONNECT两种可选值。
BASIC:是指在感知到节点故障时才创建到其他实例的连接。
PRECONNECT:是在最初建立连接时就同时建立到所有实例的连接,当发生故障时,立刻就可以切换到其他链路上。
两种方法比较:BASIC方式在Failover时会有时间延迟,PRECONNECT方式虽然没有时间延迟,但是建立多个冗余连接会消耗更多资源,两者就是是用时间换资源和用资源换时间的区别。

2.TYPE:用于定义发生故障时对完成的SQL语句如何处理,其中有2种类型:session和select.
这2种方式对于未提交的事务都会自动回滚,区别在于对select语句的处理,对于select模式,用户正在执行的select语句会被转移到新的实例上,在新的节点上继续返回后续结果集,而已经返回的记录集则抛弃。假设用户正在节点1上执行查询,整个结果集共有100条记录,现在已从节点1上返回10条记录,这时节点1宕机,用户连接被转移到节点2上。如果是session模式,则需要重新执行查询语句;如果是select方式,会从节点2上继续返回剩下的90天记录,而已经从节点1返回的10条记录不会重复返回给用户,对于用户而言,感受不到这种切换。

显然为了实现select方式,Oracle必须为每个session保存更多的内容,包括游标,用户上下文等,需要更多的资源也是用资源换时间的方案。

3.DELAY和RETRIES:这2个参数分别代表重试间隔时间和重试次数。
示例:
RAC=
    (DESCRIPTION=
     (ADDRESS=(PROTOCOL=TCP)(HOST=rac1-vip)(PORT=1521))
    (ADDRESS=(PROTOCOL=TCP)(HOST=rac2-vip)(PORT=1521))
     (LOAD_BALANCE=YES)
  (
     CONNECT_DATA=
  (SERVER=DEDICATED)
    (SERVICE_NAME=RAC)
  (
  FAILOVER_MODE=
    (TYPE=session)
    (METHOD=basic)
    (RETRIES=180)
    (DELAY=5)
    )
   )
  )


三.Service-Side TAF

Service-Side TAF的配置参考: How To Configure Server Side Transparent Application Failover [ID 460982.1]

Service-Side TAF可以看作是TAF的一种变种,首先Service-SideTAF也是TAF,所有TAF的特点它都有,其次这种TAF是在服务器上配置的,而不像TAF是在客户端配置的。

Client-SideTAF是在客户端修改tnsnames.ora文件来配置的,如果有很多客户端使用这个数据库,那么每次微笑调整都需要把所有的计算机更改一遍,既低效又容易出错。而Service-Side TAF通过结合Service,在数据库里保存FAIL_MODE的配置,把所有的TAF配置保存在数据字典中,从而省去了客户端的配置工作,现在客户端的TNS文件就不需要任何TAF的配置选项了。

从配置参数而言,Service-Side TAF和TAF相比多了一个Instance Role(实例角色)的概念。所谓的实例角色,就是当有多个Instance参与一个Service时,可以配置优先使用哪一个Instance为用户提供服务。用户共有两种可选角色。

PREFERRED:首选实例,会优先选择拥有这个角色的实例提供服务。
AVAILABLE:后备实例,用户连接会优先连接PREFFERRED的Instance,当PREFERRED的Instance不可用时,才会被转到AVAILBALE的Instance上。
要使用Server-Side TAF必须配置Service。Service可以在创建数据库时创建,也可以在创建数据库之后修改,既可以使用dbca配置向导,也可以用命令行的方式配置。

3.1用DBCA配置Service
1).运行DBCA,选择ORACLE RACApplication Clusters database
2).在第二个界面选择:Services Management
3).第三个界面会出现RAC数据库列表,用户可以在这个列表中选择要配置Service的数据库
4).在Serice配置界面中,单击Add创建新的Service,输入service名字。在Instance列表框定义实例角色,选择那个service1作为Preferred(首选实例),Service2作为   availiable(后备实例)。TAFPolicy有三个选项:None,Basic,Pre-connect。我们选Basic。最后点击Finish,完成Service配置。
5)在结束Service配置后,服务会自动启动。

3.2用srvctl命令配置Service
用命令行方式配置Service对远程维护很有用。先来看一下相关命令
1)创建service
#Srvctl add service -d -s -r "preferred-instance-list" -a "available-instance-list" -P
其中TAF-Policy可选:basic和preconnect。

例如:srvctl add service -d RAC -s Service2 -r "RAC1,RAC2" -a "RAC3,RAC4" -P basic
注意:srvctl add service中,只有perferred才会创建服务。即在OCR中注册一个ora.raw.dmm.Raw1.Srv的服务。

2)查看配置信息
#srvctl config service -d database_name [-s service_name][-a]
如果这里不指定"-s service-name",就会显示所有Service的配置,这些配置包括preferred和availableinstance.使用-a选项,还会显示TAF相关信息。

3)是否自动运行service
数据库启动时,会自动启动所有的Service。有时为了为了维护需要,需要禁用这个特性,在维护完成后再启动这个特性。
#srvctl enable/disable service -d database-name -s service-name -i instance-name

4)启动service
 #srvctl start service -d -s -i instance-name -o start -option -cconnect-string-q
如果不指定service-name,则所有的service都会被启动,可以使用逗号分隔方式,同时启动多个service。-i指定在那个实例上启动service。

5)停止service
#srvctl stop service -d -s -iinstance-name -cconnect -string-q-f
其中-f选项可以强制关闭service,并中断了其所有用户的连接。

6)查看service状态
#srvctl status service -d -s service-name- i instance-name -f -v
其中-f可以显示被disable的instance信息,而-v可以显示详细输出

7)删除service
#srvctl remove service -d database-name -s service-name -i instance-name [-f]

注意:在使用srvctl创建service时,需要注意TAF策略选项必须通过dbms_service包来配置。

示例:
Begin
  dbms_service.modify_service(Service_name = '>Service1',
                              Failover_method => dbms_service.failover_method_basic,
                              Failover_type => dbms_service.failover_type_select,
                              Failover_retries => 180,
                              Failover_delay => 5);
End;



3.3配置Service的注意事项
1).数据库的服务名是用service_name参数来指定的,一个数据库可以有多个服务名,但是service_name最长是4kb,不要手工来修改这个参数

2)最多可以创建64个service,每个数据库有2个隐含的service,因此留给用户的就只有62个service。不能修改这两个隐含service的配置,并且也不能手工启动或停止这2个服务。这两个隐含的service分别是:SYS$BACKGROUND和SYS$USERS.

3)当使用dbca配置Service时,dbca会自动更新OCR,启动Service,当删除service时,会停止service,并更新OCR.

4)使用srvctl这个工具时,命令只更新OCR中的配置,不会更新data dctionary和listener中的信息,因此还需要使用dbma_servie包来更新data dictionary,手工更改listener配置文件。故推荐使用DBCA工具来配置更改service配置

5)如果客户端想通过Service方式连接数据库,需要在tns条目中使用service_name方式引用数据库。如:
RAC=

    (DESCRIPTION=
    (ADDRESS=(PROTOCOL=TCP)(HOST=rac1-vip)(PORT=1521))
    (ADDRESS=(PROTOCOL=TCP)(HOST=rac2-vip)(PORT=1521))
    (LOAD_BALANCE=YES)
    (
   CONNECT_DATA=
 (SERVER=DEDICATED)
   (SERVICE_NAME=RAC)
   )
  )

注意:无论是使用dbca工具还是使用srvctl命令来配置service,都无法配置TAF的TYPE,DELAY,RETRIES三个属性,必须使用dbms_service包来修改这些属性。

11g中TAF的TYPE,DELAY,RETRIES三个属性配置可以用srvctl目录配置了。


注意:
客户端tnsnames.ora 中的service_name 要写我们的service-side TAF的名称。可以通过一下方式查看:

SQL> showparameter service

NAME                                      TYPE           VALUE
----------------------------------------------- -----------------
service_names                      string           dave, dave_taf

然后可以验证:
sql>show parameter instance_name

NAME            TYPE      VALUE
-----------------------------------------------------
instance_name   string    rac1

SQL>select sid from v$mystat where rownum=1;

SID

----------
146

SQL>select failover_type,failover_method,failed_over from v$session where sid=146;

FAILOVER_TYPE     FAILOVER_METHOD   FAILED_OVER
----------------------------------------------------
SELECT                 BASIC          YES

--如果客户端写的不是SERVICE-SIDE TAF的名称,而是实例的名称,那么不影响数据库的连接,但是无法实现TAF功能。



四.Srvctl命令测试实例

1.使用srvctl命令创建dmm
[oracle@raw2bin]$srvctl add service -d raw -s dmm -r"raw1,raw2" -P basic
$crs_stat-t
省略..................................................


$srvctl add service -d raw -s dmm -r raw1 -a raw2 -P basic

注意:srvctl add service中,只有perferred才会创建服务。即在OCR中注册一个ora.raw.dmm.Raw1.Srv的服务。

3)确认服务创建成功,offline表示还没有启动
$crs_stat-t

4)配置这个服务自启动
$srvctl enable service -d raw -s dmm


5)启动服务
$srvctl start service -d raw -s dmm

6)确认服务状态。Online说明已启动
$crs_stat-t


新建的服务会自动添加到初始话参数中:
show parameter service


7)用serviceTAF修改配置,需要用dbms_service.Modify_service包。
Begin
  Dbms_service.modify_service(Service_name     => 'dmm',
                              Failover_method  => dbms_service.failover_method_basic,
                              Failover_type    => dbms_service.failover_type_select,
                              Failover_retries => 180,
                              Failover_delay   => 5);
End;
/



8)确认参数已经生效
select name,failover_method,failover_type,goal,clb_goal from dba_services;


9)也可以用srvctl命令查看配置情况
$srvctl config service -d raw -s dmm -a


10)删除Service
--先关闭service:
$srvctl stop service -d raw -s dmm
$srvctl disable service -d raw -s dmm

--再删除服务:
$srvctl remove service -d raw -s dmm

如果该命令清楚不掉,我们可以加上-f参数
$srvctl remove service -d raw -s dmm -f


OCR中的信息已经被删除了,但是数据字典中的还有该service的内容,继续清除数据字典中的内容。

先查看数据字典内容:
select name,failover_method,failover_type,goal,clb_goal from dba_services;

清除数据字典里的内容:
begin
  dbms_service.delete_service(service_name => 'dmm');
end;
/


再次查询数据字典,没有了数据。清除完成
select name,failover_method,failover_type,goal,clb_goal from dba_services

到此,关于“Oracle RAC的Failover分为哪几种”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

您可能感兴趣的文档:

--结束END--

本文标题: Oracle RAC的Failover分为哪几种

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

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

猜你喜欢
  • Oracle RAC的Failover分为哪几种
    这篇文章主要介绍“Oracle RAC的Failover分为哪几种”,在日常操作中,相信很多人在Oracle RAC的Failover分为哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2024-04-02
  • oracle中触发器分为哪几种
    oracle 触发器类型包括:1. insert(记录插入时触发);2. update(记录更新时触发);3. delete(记录删除时触发);4. before(事件前执行动作);5....
    99+
    2024-05-09
    oracle
  • SSL证书分为哪几种
    SSL证书分为:1、域名型DVSSL证书,只需域名所有权验证,适合个人站点使用;2、企业级OVSSL证书,需要验证域名所有权,企业营业执照或事业单位法人证书等,适合电子商务站点和中小型企业站点使用;3、增强型EVSSL证书,需要验证域名所有...
    99+
    2024-04-02
  • HTTP代理分为哪几种类
    这篇文章主要介绍“HTTP代理分为哪几种类”,在日常操作中,相信很多人在HTTP代理分为哪几种类问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”HTTP代理分为哪几种类”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-25
  • php静态化分为哪几种
    今天小编给大家分享一下php静态化分为哪几种的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在PHP中静态化分为两种,分别是:...
    99+
    2023-06-29
  • 流量分为哪几种等级
    流量分为用户流量、网站流量和网络流量三种等级。这三种流量相互关联,共同构成了互联网世界的重要组成部分。详细介绍:用户流量是个人行为的指标,用于衡量一个人在互联网上的活动和消费能力;网站流量、是一个网站的活跃程度和受欢迎程度的指标;而网络流量...
    99+
    2023-08-08
  • 流量分为哪几种类型
    流量的类型分为网络流量、网站流量、应用程序流量、视频流量、短信流量、数据中心流量等不同的类型。详细介绍:1、网络流量分为上行流量和下行流量,上行流量是指用户发送到互联网的数据量,例如上传文件、发送电子邮件等,下行流量是指从互联网传输到用户设...
    99+
    2023-08-08
  • 计算机内存分为哪几种
    计算机内存可以分为ROM和RAM两种,其中RAM是随机存取存储器,特点是断电会丢失内存;ROM则是固化存储器,断电不会丢失内存。计算机内存可以分为:ROMROM是只读存储器,其特点是只能读出不能随意写入信息,主要作用是完成对系统的加电自检、...
    99+
    2024-04-02
  • Oracle RAC中的几个IP
    oracle11g开始,设置了SCAN ip,除此之外还有public ip,virtual ip,private ip,容易让人犯晕。下面逐一解释:public ip:   ...
    99+
    2024-04-02
  • 云服务器类型分为哪几种
    云服务器类型可以分为以下几种: 公共云:通常是一组计算、存储和网络资源,由许多提供者提供。这种云可以在全球范围内使用,并且使用成本非常低。 私有云:通常是一组计算、存储和网络资源,只为特定公司或组织提供。这些提供者专门设计、维护和管理资...
    99+
    2023-10-27
    几种 类型 服务器
  • oracle优化器参数的值可以分为几种
    本篇内容介绍了“oracle优化器参数的值可以分为几种”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • java中的注释可分为哪几种类型
    在Java中,注释可以分为三种类型:1. 单行注释(//):以双斜线(//)开头,表示注释的内容仅在同一行有效。示例:```// 这...
    99+
    2023-08-23
    java
  • 免备案空间租用分为哪几种
    免备案空间租用分为:1、香港空间租用,采用国际带宽,能实现全球访问;2、国外空间租用,指在其他国家服务器租用或是托管服务器;3、国内免备案空间租用,是一些私人或是小厂家,IDC服务商不正规,网站的安全性和稳定性没有保证。具体内容如下:1、香...
    99+
    2024-04-02
  • 域名服务器分为哪几种类型
    域名服务器分为以下几种类型:1. 主域名服务器(Master DNS Server):主要负责管理一个域名的解析记录,通常由域名所有...
    99+
    2023-06-06
    域名服务器 服务器 域名
  • 数据可视化组件分为哪几种
    常见的数据可视化组件包括:1. 图表:如折线图、柱状图、饼图、散点图、雷达图等。2. 地图:如热力图、地图标记、地图区域填充等。3....
    99+
    2023-06-08
    数据可视化组件
  • DDoS攻击通常分为哪几种类型
    DDoS攻击通常分为以下几种类型: 网络层攻击:通过发送大量的数据包来消耗目标服务器的网络带宽,使其无法正常工作。 传输层攻...
    99+
    2024-04-15
    DDoS攻击
  • oracle中的索引有哪几种
    oracle 支持的索引类型包括:b-tree 索引:用于快速等值、范围和前缀查询hash 索引:用于极快速的等值查询位图索引:用于查询布尔字段函数索引:用于查询函数或表达式产生的列空间...
    99+
    2024-05-08
    oracle
  • 免实名服务器租用分为哪几种
    免实名服务器租用分为:1、香港服务器租用,采用国际带宽,能实现全球访问;2、国外服务器租用,指在其他国家服务器租用或是托管服务器;3、国内免备案服务器租用,是由不正规的私人公司或小厂家提供的服务器,安全性和稳定性没有保障。具体内容如下:1、...
    99+
    2024-04-02
  • 租用免备案服务器分为哪几种
    租用免备案服务器分为:1、香港服务器租用,不需要单独备案,可以直接用来做网站或是做其他事情;2、国外服务器租用,指在其他国家服务器租用或是托管服务器;3、国内免备案服务器租用,由不正规的IDC服务器商提供,网站的安全性和稳定性不高。具体内容...
    99+
    2024-04-02
  • 免备案服务器租用分为哪几种
    免备案服务器租用分为:1、香港服务器租用,使用国际带宽,能实现全球访问;2、国外服务器租用,指在其他国家服务器租用或是托管服务器;3、国内免备案服务器租用,需要备案才能打开网站,不需要备案也能打开网站的服务商,所提供的服务器安全性和稳定性没...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作