欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    Oracle 11g R2 RAC高可用连接特性SCAN详解解读.docx

    • 资源ID:10537047       资源大小:26.46KB        全文页数:23页
    • 资源格式: DOCX        下载积分:10金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Oracle 11g R2 RAC高可用连接特性SCAN详解解读.docx

    1、Oracle 11g R2 RAC高可用连接特性 SCAN详解解读SCAN概念先介绍一下什么叫SCAN,SCAN(Single Client Access Name)是Oracle从11g R2开始推出的,客户端可以通过SCAN特性负载均衡地连接到RAC数据库。SCAN提供一个域名来访问RAC,域名可以解析1个到3个(注意,最多3个)SCAN IP,我们可以通过DNS或者GNS来解析实现。其中DNS大家都很熟悉,这里不多说。GNS(Grid Naming Service)则是Oracle 11g R2的新功能,可以通过DHCP服务为节点和SCAN分配VIP和SCAN IP。另外还有个优点是,对

    2、于新加入集群的节点,它会自动分配VIP地址,更新集群资源,客户端依然通过SCAN特性负载均衡地连接到新增集群节点上。DNS和GNS配置与解析相关内容在下面还有说明。除了DNS和GNS解析方法外,SCAN也可以使用hosts文件来解析,但用过的人都知道,此方法不仅在安装RAC的时候产生问题,后期使用也是存在问题的,比如SCAN域名只能定义一个SCAN IP。所以这种方法也是Oracle不推荐使用的。但尽管如此,我见过很多生产上依然这样使用,也就是废弃了11g的新特性SCAN,而是依然采用VIP连接方式。备注:有人可能会注意到此方法不仅在安装RAC的时候产生问题这句,RAC安装的时候的确会报错,但

    3、这并不影响后期Oracle的使用。SCAN最明显的优点就是,当集群中新增加了节点或者删除了节点,不需要额外维护客户端。PUBLIC IP, PRIVATE IP, VIP, SCAN VIP, GNS VIP, LOCAL_LISTENER, REMOTE_LISTENER , LOCAL LISTENER, SCAN LISTENER在RAC部署的时候,我们都会接触到PUBLIC IP、PRIVATE I、VIP等等,那下面就针对它们进行介绍。PUBLIC IP :这是我们网卡上配置的真实IP地址,我们称为公共IP,这个IP的存在关系到下面介绍的VIP能不能正确漂在其所在网卡上。注意,PUB

    4、LIC IP是不提供给客户端去连接配置的,这并不是说通过PUBLIC IP无法连接实例,而是它会存在节点服务器宕机的时候所有向它请求的客户端都会有等待现象并且最后得到超时信息的缺点。PRIVATE IP :称为私网IP(私有IP),它是用于心跳同步的,也就是保证两台服务器数据同步。说道私网IP,我简单说下Oracle另一个高可用性连接特性 HAIP。其实Cache Fusion会消耗节点服务器很大的私网资源,另外,私网间无法通信还会引起brain split(脑裂),以前为解决这种问题,我们可以采用网卡bonding技术,而Oracle在11g R2的时候HAIP技术来实现,HAIP(High

    5、ly Available Virtual IP)用于节点间的私网通信,支持同时使用多个网络连接来满足网卡间的负载均衡,并且还提高了Cache Fusion资源通信能力。HAIP技术并不是主要内容,所以在这里点到为止。VIP :RAC的每个节点都需要有一个虚拟IP,这就是VIP。VIP需要和PUBLIC IP同一个子网,它们是由GI的Clusterware来管理的。VIP在其节点服务器发生故障的时候会自动漂移到另外正常的节点服务器上,如果RAC是多个节点运行的,那具体漂移到哪个活动的节点将由Clusterware决定。VIP发生漂移现象之后,其当前的节点服务器LOCAL LISTENER是不会监

    6、听它的请求的,所以有客户端向这个VIP发送请求时,Clusterware的FAN会通知客户端向别的VIP发送请求,客户端收到通知后通过Failover机制把请求重新发送到ADDRESS列表中的其他VIP上。虽然有这种较复杂的过程,但始终对客户端是透明进行的,而且这个过程完成时间非常短暂,客户端也就几乎感受不到有节点宕机。等故障节点恢复正常,漂移的VIP也回到此节点上,继续提供服务。SCAN VIP :SCAN VIP就是我在刚开始常说的SCAN IP,也就是由DNS或者GNS、hosts解析出来的IP地址。上面也说过,SCAN VIP最多能有三个,它们循环地被客户端所请求到。这里大家可能会存在

    7、这样的问题,SCAN VIP只有三个,那RAC是四节点或更多的节点情况怎么办?存在这种问题的原因归咎于对SCAN VIP的了解不足。其实,SCAN VIP数量和节点数是没有任何关系的,SCAN VIP会落到哪个节点上都是随机的。GNS VIP :GNS VIP同SCAN VIP,也是Oracle从11g R2开始提供的。GNS VIP是提供GNS服务的IP地址,它绑定到某个节点的PUBLIC IP所在网卡上,当节点出现故障,GNS资源会自动切换到其他正常的节点继续提供GNS解析服务。如果我们不使用GNS解析方法,那么也不会存在GNS VIP。LOCAL LISTENER :本地监听器,RAC的

    8、每个节点上都会有独立的本地监听器,它会监听该节点的PUBLIC IP和VIP,而每个节点的实例在启动的时候也向本地监听器进行注册,当然它也会向SCAN监听器注册,当VIP或者PUBLIC IP(这种情况比较少见)有连接请求的时候,本地监听器就接受处理并和本地实例建立连接。如果某个节点故障,其上面的VIP会进行漂移,但本地监听器并不会产生漂移。SCAN LISTENER :SCAN监听器,它是实现SCAN负载均衡的原理所在。如果RAC上有三个SCAN VIP,那么SCAN监听器也有三个,它们各自监听SCAN VIP的连接请求。SCAN监听器跟着SCAN VIP随机分配到节点服务器上,如果某个节点

    9、发生故障,运行在此节点上的SCAN VIP会进行漂移,这时候SCAN监听器也跟着漂移到正常的节点上,继续为SCAN VIP监听连接请求,当PMON进程下次动态更新实例信息到该SCAN监听器之后,它又重新接受客户端的连接。这和VIP产生漂移的时候是有所区别的。LOCAL_LISTENER :这是Oracle的参数,这个参数控制着本地监听器的注册,因为本地监听器的工作机制关系,通过本地监听器的数据库连接请求只会连接到本地节点的实例上。REMOTE_LISTENER : 同LOCAL_LISTENER是Oracle的参数,通过这个设置,任何实例都会向SCAN监听器注册,所以SCAN监听器能够负载均衡

    10、地分发连接请求到节点本地监听器上,也就是连接到其本地节点上实例上。关于LOCAL_LISTENER与REMOTE_LISTENER的配置,在下面讲动态注册的时候再看一下。SCAN解析与配置SCAN是在安装GI(Grid Infrastructure)时配置的,作为Clusterware资源被管理。忽略hosts解析之后,有两种方式配置和解析SCAN: DNS和GNS(Grid Naming Service)。这里重点说一下DNS解析SCAN方式使用DNS解析SCAN的时候,DNS服务器会采用rr(round-robin)的方式循环解析为它准备的3个IP地址,与Oracle 11g R2的客户端

    11、配合使不同的客户端能够连接到不同的SCAN Listener上,这相当于是Oracle 10g中配置的客户端负载均衡(通过LOAD_BALANCE=yes配置)。下面看一下客户端通过SCAN连接到数据库的过程,首先由DNS服务器解析SCAN名称,DNS服务器返回SCAN对应的3个IP地址的列表,客户端会选择使用其中一个SCAN VIP地址作为连接地址,将命名方法解析后的连接信息发送到SCAN VIP对应的SCAN Listener上,SCAN Listener通过负载均衡机制再把请求转发给比较空闲的服务器上的本地监听器,由本地监听器完成实例与客户端之间的连接。使用SCAN连接数据库实例,整个过

    12、程实现了客户端的Failover(Oracle 10g R2是通过FAILOVER=on来配置),DNS服务器返回的是一个SCAN VIP列表,客户端会选择其中一个连接到RAC,如果这个IP地址不能正常访问,客户端会选择另一个IP地址继续连接,直到所有的地址都不能正常连接,才返回错误给客户端,整个过程对客户端程序来说依然是透明的。需要注意的是,使用SCAN连接到数据库,不再需要客户端能解析节点的PUBLIC IP和VIP,只需要客户端能够通过DNS服务器正常解析SCAN就可以了。负载均衡工作交给服务器端的SCAN实现。至于GNS解析SCAN,因为目前GNS服务存在不稳定的情况,也很少有企业将其

    13、投入到生产环境使用,而且其工作原理也较为复杂,所以在这里并不深入说明。实例的动态注册上面已经介绍了LOCAL_LISTENER和REMOTE_LISTENER两个和动态注册有关的参数,那我们看看它们在数据库中的表现形式:本地监听器注册是由实例的LOCAL_LISTENER参数所控制的:SQL set line 150SQL show parameter local_listenerNAME TYPE VALUE - local_listener string (DESCRIPTION=(ADDRESS_LIST=(AD DRESS=(PROTOCOL=TCP)(HOST=192. 168.0.

    14、194)(PORT=1521) 这是我管理的一套RAC上的配置,当然我已经处理好IP地址了。LOCAL_LISTENER设置为向本地VIP地址进行注册,由于本地监听器是在本地的PUBLIC IP和VIP上监听,所以向VIP监听注册就能保证成功向本地监听器注册。查看本地监听器的状态:gridpos2 $ lsnrctl status listenerLSNRCTL for Linux: Version 11.2.0.3.0 Production on 23-OCT-2012 12:01:21Copyright (c) 1991, 2011, Oracle. All rights reserved

    15、.Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER)STATUS of the LISTENERAlias LISTENERVersion TNSLSNR for Linux: Version 11.2.0.3.0 ProductionStart Date 19-JUL-2012 15:31:45Uptime 95 days 20 hr. 29 min. 35 secTrace Level offSecurity ON: Local OS AuthenticationSNMP OFFListener Paramete

    16、r File /u01/app/11.2.0/grid/network/admin/listener.oraListener Log File /u01/app/grid/diag/tnslsnr/pos2/listener/alert/log.xmlListening Endpoints Summary (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER) (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.0.192)(PORT=1521) (DESCRIPTION=(ADDRESS=(PROT

    17、OCOL=tcp)(HOST=192.168.0.194)(PORT=1521)Services SummaryService +ASM has 1 instance(s). Instance +ASM2, status READY, has 1 handler(s) for this serviceService pos has 1 instance(s). Instance pos2, status READY, has 1 handler(s) for this serviceService posXDB has 1 instance(s). Instance pos2, status

    18、READY, has 1 handler(s) for this serviceThe command completed successfully 这里注意:查看本地监听器信息的时候每个节点只能看到其上运行的实例。SCAN监听器的注册是由REMOTE_LISTENER参数控制的,任何实例都会向所有的SCAN监听器注册:SQL show parameter remote_listenerNAME TYPE VALUE - remote_listener string pos-cluster-scan:1521下面是LISTENER_SCAN1的一个状态信息,当然你也可以查看LISTENER_S

    19、CAN2和LISTENER_SCAN3的状态。gridpos2 $ lsnrctl status listener_scan1LSNRCTL for Linux: Version 11.2.0.3.0 Production on 23-OCT-2012 12:06:56Copyright (c) 1991, 2011, Oracle. All rights reserved.Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER_SCAN1)STATUS of the LISTENERAlias LISTENER_SCAN

    20、1Version TNSLSNR for Linux: Version 11.2.0.3.0 ProductionStart Date 19-JUL-2012 15:31:45Uptime 95 days 20 hr. 35 min. 10 secTrace Level offSecurity ON: Local OS AuthenticationSNMP OFFListener Parameter File /u01/app/11.2.0/grid/network/admin/listener.oraListener Log File /u01/app/11.2.0/grid/log/dia

    21、g/tnslsnr/pos2/listener_scan1/alert/log.xmlListening Endpoints Summary (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER_SCAN1) (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.0.195)(PORT=1521)Services SummaryService pos has 2 instance(s). Instance pos1, status READY, has 1 handler(s) for this ser

    22、vice Instance pos2, status READY, has 1 handler(s) for this serviceService posXDB has 2 instance(s). Instance pos1, status READY, has 1 handler(s) for this service Instance pos2, status READY, has 1 handler(s) for this serviceThe command completed successfully由于任何实例启动都会向所有的SCAN监听器动态注册,从LISTENER_SCAN

    23、1的SCAN监听器运行状态来看,SERVICE pos包括了所有的实例名称。就像我昨天回答那位朋友的时候简单说“是通过内部机制”一样,大家可能看到上面的内容并不知道SCAN监听器如何找到比较空闲的实例的。其实SCAN监听器是实时了解所有实例的运行情况的,因此它能够准确地将连接重定向到空闲服务器的本地监听器上。下面我们通过日志查看实例的动态注册与动态更新1)本地监听器动态注册日志:gridpos2 $ cd $ORACLE_BASE/diag/tnslsnr/pos2/listener/alertgridpos2 alert$ grep service_register log_1.xml |

    24、head -3 18-JUN-2012 13:58:23 * service_register * LsnrAgt * 0 18-JUN-2012 13:58:30 * service_register * +ASM2 * 0 18-JUN-2012 15:54:15 * service_register * pos2 * 0- 之所以选择log_1.xml历史文件是因为发现我的log.xml里基本都是更新日志,没有注册日志。2)本地监听器动态更新日志:gridpos2 alert$ grep service_update log.xml | head -3 16-OCT-2012 16:07

    25、:09 * service_update * pos2 * 0 16-OCT-2012 16:07:33 * service_update * pos2 * 0 16-OCT-2012 16:08:03 * service_update * pos2 * 03)SCAN监听器动态注册日志:gridrac1 $ cd $ORACLE_BASE/diag/tnslsnr/rac1/listener_scan2/alert/gridrac1 $ grep service_register log.xml | head -3 13-AUG-2012 05:25:00 * service_registe

    26、r * LsnrAgt * 0 13-AUG-2012 20:29:07 * service_register * luocs1 * 0 13-AUG-2012 20:58:05 * service_register * luocs1 * 0- 这是我另一套测试RAC环境。4)SCAN监听器动态更新日志:gridrac1 $ grep service_update log.xml | head -3 13-AUG-2012 20:29:19 * service_update * luocs1 * 0 13-AUG-2012 20:30:19 * service_update * luocs1

    27、* 0 13-AUG-2012 20:30:46 * service_update * luocs1 * 0注意,如果你的RAC是通过hosts解析了SCAN域名的,那么系统里就找不到上面的SCAN监听器日志的路径。实例的动态注册和动态更新过程是由实例的PMON进程完成的,正是因为SCAN监听器能够实时了解实例的负载情况,所以SCAN监听器能够负载均衡地将连接请求转发给合适实例的本地监听器来处理。这里谈到负载均衡,那么就说下负载均衡中的优先级共享服务器配置中: 低负载节点 低负载实例 实例相关的低负载调度器专用服务器配置中: 低负载节点 低负载实例SCAN兼容性配置介绍SCAN差不多了,这里还

    28、有个兼容性问题不能不说。要完美实现SCAN功能特性,其实对客户端的要求也是存在的。下面看下不同版本和SCAN之间的兼容性编号客户端软件版本服务器端软件版本SCAN特性的使用111gR211gR2能够充分使用SCAN的特性2早于11gR2版本11gR2不能充分感受到SCAN特性311gR2早于11gR2版本在服务器端没有SCAN的概念4早于11gR2版本早于11gR2版本在服务器端没有SCAN的概念这里稍微详细说一下第2种情况,如果客户端低于11g R2的版本,在DNS解析的3个VIP地址中,可能只能固定地使用第一个SCAN VIP连接数据库;如果该SCAN VIP对应的监听器出现故障,那么整个

    29、连接将会失败,客户端也会收到到错误信息。那针对兼容性问题我们拿出各种客户端配置方法1)客户端和服务器端软件版本都是11g R2的时候Tnsnames.oraRACSCAN = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = luocs-cluster-)(PORT = 1521) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = luocs10g) ) )2)客户端是早于11g R2的版本,服务器端是11g R2的时候RACSCAN = (DESCRIPTION = (ADDRESS_LIST = (LOAD_BALANCE=on) (FAILOVER=on) (ADDRESS = (PROTOCOL = TCP)(HOS


    注意事项

    本文(Oracle 11g R2 RAC高可用连接特性SCAN详解解读.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开