您好,欢迎访问三七文档
当前位置:首页 > IT计算机/网络 > 数据库 > Oracle-11g-R2-RAC高可用连接特性-–-SCAN详解
SCAN概念先介绍一下什么叫SCAN,SCAN(SingleClientAccessName)是Oracle从11gR2开始推出的,客户端可以通过SCAN特性负载均衡地连接到RAC数据库。SCAN提供一个域名来访问RAC,域名可以解析1个到3个(注意,最多3个)SCANIP,我们可以通过DNS或者GNS来解析实现。其中DNS大家都很熟悉,这里不多说。GNS(GridNamingService)则是Oracle11gR2的新功能,可以通过DHCP服务为节点和SCAN分配VIP和SCANIP。另外还有个优点是,对于新加入集群的节点,它会自动分配VIP地址,更新集群资源,客户端依然通过SCAN特性负载均衡地连接到新增集群节点上。DNS和GNS配置与解析相关内容在下面还有说明。除了DNS和GNS解析方法外,SCAN也可以使用hosts文件来解析,但用过的人都知道,此方法不仅在安装RAC的时候产生问题,后期使用也是存在问题的,比如SCAN域名只能定义一个SCANIP。所以这种方法也是Oracle不推荐使用的。但尽管如此,我见过很多生产上依然这样使用,也就是废弃了11g的新特性SCAN,而是依然采用VIP连接方式。备注:有人可能会注意到《此方法不仅在安装RAC的时候产生问题》这句,RAC安装的时候的确会报错,但这并不影响后期Oracle的使用。SCAN最明显的优点就是,当集群中新增加了节点或者删除了节点,不需要额外维护客户端。PUBLICIP,PRIVATEIP,VIP,SCANVIP,GNSVIP,LOCAL_LISTENER,REMOTE_LISTENER,LOCALLISTENER,SCANLISTENER在RAC部署的时候,我们都会接触到PUBLICIP、PRIVATEI、VIP等等,那下面就针对它们进行介绍。PUBLICIP:这是我们网卡上配置的真实IP地址,我们称为公共IP,这个IP的存在关系到下面介绍的VIP能不能正确漂在其所在网卡上。注意,PUBLICIP是不提供给客户端去连接配置的,这并不是说通过PUBLICIP无法连接实例,而是它会存在节点服务器宕机的时候所有向它请求的客户端都会有等待现象并且最后得到超时信息的缺点。PRIVATEIP:称为私网IP(私有IP),它是用于心跳同步的,也就是保证两台服务器数据同步。说道私网IP,我简单说下Oracle另一个高可用性连接特性–HAIP。其实CacheFusion会消耗节点服务器很大的私网资源,另外,私网间无法通信还会引起brainsplit(脑裂),以前为解决这种问题,我们可以采用网卡bonding技术,而Oracle在11gR2的时候HAIP技术来实现,HAIP(HighlyAvailableVirtualIP)用于节点间的私网通信,支持同时使用多个网络连接来满足网卡间的负载均衡,并且还提高了CacheFusion资源通信能力。HAIP技术并不是主要内容,所以在这里点到为止。VIP:RAC的每个节点都需要有一个虚拟IP,这就是VIP。VIP需要和PUBLICIP同一个子网,它们是由GI的Clusterware来管理的。VIP在其节点服务器发生故障的时候会自动漂移到另外正常的节点服务器上,如果RAC是多个节点运行的,那具体漂移到哪个活动的节点将由Clusterware决定。VIP发生漂移现象之后,其当前的节点服务器LOCALLISTENER是不会监听它的请求的,所以有客户端向这个VIP发送请求时,Clusterware的FAN会通知客户端向别的VIP发送请求,客户端收到通知后通过Failover机制把请求重新发送到ADDRESS列表中的其他VIP上。虽然有这种较复杂的过程,但始终对客户端是透明进行的,而且这个过程完成时间非常短暂,客户端也就几乎感受不到有节点宕机。等故障节点恢复正常,漂移的VIP也回到此节点上,继续提供服务。SCANVIP:SCANVIP就是我在刚开始常说的SCANIP,也就是由DNS或者GNS、hosts解析出来的IP地址。上面也说过,SCANVIP最多能有三个,它们循环地被客户端所请求到。这里大家可能会存在这样的问题,SCANVIP只有三个,那RAC是四节点或更多的节点情况怎么办?存在这种问题的原因归咎于对SCANVIP的了解不足。其实,SCANVIP数量和节点数是没有任何关系的,SCANVIP会落到哪个节点上都是随机的。GNSVIP:GNSVIP同SCANVIP,也是Oracle从11gR2开始提供的。GNSVIP是提供GNS服务的IP地址,它绑定到某个节点的PUBLICIP所在网卡上,当节点出现故障,GNS资源会自动切换到其他正常的节点继续提供GNS解析服务。如果我们不使用GNS解析方法,那么也不会存在GNSVIP。LOCALLISTENER:本地监听器,RAC的每个节点上都会有独立的本地监听器,它会监听该节点的PUBLICIP和VIP,而每个节点的实例在启动的时候也向本地监听器进行注册,当然它也会向SCAN监听器注册,当VIP或者PUBLICIP(这种情况比较少见)有连接请求的时候,本地监听器就接受处理并和本地实例建立连接。如果某个节点故障,其上面的VIP会进行漂移,但本地监听器并不会产生漂移。SCANLISTENER:SCAN监听器,它是实现SCAN负载均衡的原理所在。如果RAC上有三个SCANVIP,那么SCAN监听器也有三个,它们各自监听SCANVIP的连接请求。SCAN监听器跟着SCANVIP随机分配到节点服务器上,如果某个节点发生故障,运行在此节点上的SCANVIP会进行漂移,这时候SCAN监听器也跟着漂移到正常的节点上,继续为SCANVIP监听连接请求,当PMON进程下次动态更新实例信息到该SCAN监听器之后,它又重新接受客户端的连接。这和VIP产生漂移的时候是有所区别的。LOCAL_LISTENER:这是Oracle的参数,这个参数控制着本地监听器的注册,因为本地监听器的工作机制关系,通过本地监听器的数据库连接请求只会连接到本地节点的实例上。REMOTE_LISTENER:同LOCAL_LISTENER是Oracle的参数,通过这个设置,任何实例都会向SCAN监听器注册,所以SCAN监听器能够负载均衡地分发连接请求到节点本地监听器上,也就是连接到其本地节点上实例上。关于LOCAL_LISTENER与REMOTE_LISTENER的配置,在下面讲动态注册的时候再看一下。SCAN解析与配置SCAN是在安装GI(GridInfrastructure)时配置的,作为Clusterware资源被管理。忽略hosts解析之后,有两种方式配置和解析SCAN:DNS和GNS(GridNamingService)。这里重点说一下DNS解析SCAN方式使用DNS解析SCAN的时候,DNS服务器会采用rr(round-robin)的方式循环解析为它准备的3个IP地址,与Oracle11gR2的客户端配合使不同的客户端能够连接到不同的SCANListener上,这相当于是Oracle10g中配置的客户端负载均衡(通过LOAD_BALANCE=yes配置)。下面看一下客户端通过SCAN连接到数据库的过程,首先由DNS服务器解析SCAN名称,DNS服务器返回SCAN对应的3个IP地址的列表,客户端会选择使用其中一个SCANVIP地址作为连接地址,将命名方法解析后的连接信息发送到SCANVIP对应的SCANListener上,SCANListener通过负载均衡机制再把请求转发给比较空闲的服务器上的本地监听器,由本地监听器完成实例与客户端之间的连接。使用SCAN连接数据库实例,整个过程实现了客户端的Failover(Oracle10gR2是通过FAILOVER=on来配置),DNS服务器返回的是一个SCANVIP列表,客户端会选择其中一个连接到RAC,如果这个IP地址不能正常访问,客户端会选择另一个IP地址继续连接,直到所有的地址都不能正常连接,才返回错误给客户端,整个过程对客户端程序来说依然是透明的。需要注意的是,使用SCAN连接到数据库,不再需要客户端能解析节点的PUBLICIP和VIP,只需要客户端能够通过DNS服务器正常解析SCAN就可以了。负载均衡工作交给服务器端的SCAN实现。至于GNS解析SCAN,因为目前GNS服务存在不稳定的情况,也很少有企业将其投入到生产环境使用,而且其工作原理也较为复杂,所以在这里并不深入说明。实例的动态注册上面已经介绍了LOCAL_LISTENER和REMOTE_LISTENER两个和动态注册有关的参数,那我们看看它们在数据库中的表现形式:本地监听器注册是由实例的LOCAL_LISTENER参数所控制的:SQLsetline150SQLshowparameterlocal_listenerNAMETYPEVALUE———————————————————-——————————local_listenerstring(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.194)(PORT=1521))))–这是我管理的一套RAC上的配置,当然我已经处理好IP地址了。LOCAL_LISTENER设置为向本地VIP地址进行注册,由于本地监听器是在本地的PUBLICIP和VIP上监听,所以向VIP监听注册就能保证成功向本地监听器注册。查看本地监听器的状态:[grid@pos2~]$lsnrctlstatuslistenerLSNRCTLforLinux:Version11.2.0.3.0–Productionon23-OCT-201212:01:21Copyright(c)1991,2011,Oracle.Allrightsreserved.Connectingto(DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=LISTENER)))STATUSoftheLISTENER————————AliasLISTENERVersionTNSLSNRforLinux:Version11.2.0.3.0–ProductionStartDate19-JUL-201215:31:45Uptime95days20hr.29min.35secTraceLeveloffSecurityON:LocalOSAuthenticationSNMPOFFListenerParameterFile/u01/app/11.2.0/grid/network/admin/listener.oraListenerLogFile/u01/app/grid/diag/tnslsnr/pos2/listener/alert/log.xmlListeningEndpointsSummary…(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER)))(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.0.192)(PORT=1521)))(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.0.194)(PORT=1521)))ServicesSummary…Service+ASMhas1instance(s).Instance+ASM2,statusREADY,has1handler(s)forthisservice…Serviceposhas1instance(s).Instancepos2,statusREADY,has1handler(s)forthisservice…ServiceposXDBhas1instance(s).Instancepos2,statusREADY,has1handler(s)forthisservice…Thecommandcompletedsuccessfully–这里注意:查看
本文标题:Oracle-11g-R2-RAC高可用连接特性-–-SCAN详解
链接地址:https://www.777doc.com/doc-4590335 .html