在介绍SCAN之前, 先简单的回顾一下ORACLE 关于IP 地址的命名用, 在9I RAC时, ORACLE没有自己的CLUSTERWARE, 主要依靠第三方的集群软件(如HACMP等), 客户端主要是通过PUBLIC IP来访问数据库, 当某一个节点已经出现故障无法对外提供服务时, 如果客户端继续请求连接这个节点的PUBLIC IP, 那么连接请求会长时间没有返回, 最后要等到TCP-IP TIMEOUT才会返回一个超时信息, 这对于实时性要求较高的应用来说是致命问题, 很多DBA都经历过这样的问题, 从技术层面上来说, 这是一个网络层的问题, 任何应用都要等待网络层返回超时信息。 为了解决这个问题, 从ORACLE 10G RAC开始, 引入了一个新的功能叫VIP, 这个功能类似于第三方集群软件的浮动IP, 简单的说就是当PUBLIC 网卡或者节点出现问题, VIP可以快速的FAILOVER到另外的节点, 如果客户端的连接请求被分配到这个VIP时, 客户端连接请求马上就会遇到错误, 因此会快速的跳过这个有问题的VIP, 而重新分配另一个VIP, 最终连接到数据库, 这些对于应用来说是透明的, 基本感觉不到连接的延时。
 
二。 SCAN
       从11GR2 GRID INFRASTRUCTURE开始, 引入了一个新功能叫SCAN(SINGLE CLIENT ACCESS NAME), SCAN是一个域名, 可以解析到少一个IP, 最多解析三个SCAN IP, 客户端可以通过这个SCAN名字来访问数据库,SCAN的好处就是当集群中新增加或者删除节点, 不需要额外维护客户端, 在11GR2上, 客户端仍然可以继续使用原有的VIP, 但是ORCLE 推荐使用SCAN。
       SCAN IP 必须与PUBLIC IP和VIP在一个子网, 同时ORACLE 推荐使用DNS或者GNS来解析SCAN, 如果没有使用DNS或者GNS的放在, 可以使用HOSTS文件, 但是这个办法不是ORACLE 推荐的, 因为这个方法只能定义一个SCAN IP。
       GRID集群中有2类资源是与SCAN有关的, 一类是SCAN IP, 另一类是SCAN LISTENER, SCAN IP和SCAN LISTENER是成对出现的, 也就是说如果有3个SCAN IP, 就会同时有3个SCAN LISTENER。 SCAN IP 就是DNS解析的IP 地址, SCAN LISTENER的作用是接受客户端的连接请求。
        数据库的初始化参数REMOTE_LISTENER默认被设置为SCAN LISTENER, 目的是为了让SCAN LISTENER可以监听所有的关例, 记录所有实例的压力, 以便于按照负载均衡的方式来转发客户端的请求。

  1. SQL> show parameter remote
  2. NAME                                 TYPE        VALUE
  3. ------------------------------------ ----------- ------------------------------
  4. remote_dependencies_mode             string      TIMESTAMP
  5. remote_listener                      string      racscan:1521
  6. remote_login_passwordfile            string      EXCLUSIVE
  7. remote_os_authent                    boolean     FALSE
  8. remote_os_roles                      boolean     FALSE
  9. result_cache_remote_expiration       integer     0

三, 客户端访问方式
       客户端发出连接数据库的请求, DNS将SCAN解析出对应的3个SCAN IP并返回给客户端, 客户端随机的选择其中一个SCAN IP 地址, 然后客户端通过这个SCAN IP访问对应的节点, 当对应节点的SCAN LISTENER接受到请求后, SCAN LISTENER会选择压力最小的数据库实例, 然后压力最小的数据库实例对应的LOCAL LISTENER的地址将返回给客户端, 最终这个LOCAL LISTENER为客户端的请求建立与数据库的连接。

四, 客户端连接配置

  1. ORA11G =
  2. (DESCRIPTION =
  3. (ADDRESS = (PROTOCOL = TCP)(HOST = racscan)(PORT = 1521))
  4. (CONNECT_DATA =
  5. (SERVER = DEDICATED)
  6. (SERVICE_NAME = ora11g)
  7. )
  8. )

五, SCAN的常用命令
1. 查看SCAN配置信息

  1. [grid@rac1 ~]$ srvctl config scan
  2. SCAN name: racscan, Network: 1/192.168.3.0/255.255.255.0/eth0
  3. SCAN VIP name: scan1, IP: /racscan/192.168.3.198

2. 查看SCAN LISTENER配置信息

  1. [grid@rac1 ~]$ srvctl config scan_listener
  2. SCAN Listener LISTENER_SCAN1 exists. Port: TCP:1521

3. 查看SCAN的状态

  1. [grid@rac1 ~]$ srvctl status scan
  2. SCAN VIP scan1 is enabled
  3. SCAN VIP scan1 is running on node rac1

4. 查看SCAN LISTENER的状态

    1. [grid@rac1 ~]$ srvctl status scan_listener
    2. SCAN Listener LISTENER_SCAN1 is enabled
    3. SCAN listener LISTENER_SCAN1 is running on node rac1

RAC SCAN的更多相关文章

  1. [转]Oracle 11g RAC SCAN ip的原理及配置

    原文地址:http://tiany.blog.51cto.com/513694/1421917/ Oracle 11g RAC SCAN ip的原理及配置   Oracle 11g RAC网格即插即用 ...

  2. oracle rac scan ip 用途 原理

    Oracle 11G R2 RAC增加了scan ip功能,在11.2之前,client链接数据库的时候要用vip,假如你的cluster有4个节点,那么客户端的tnsnames.ora中就对应有四个 ...

  3. [转]Oracle 11g R2 RAC高可用连接特性 – SCAN详解

    原文地址:http://czmmiao.iteye.com/blog/2124373   昨天帮朋友解决11g RAC SCAN问题,当时为这朋友简单解答了一些SCAN特性相关的问题,但我知道这仅仅是 ...

  4. Oracle RAC学习笔记01-集群理论

    Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...

  5. Oracle 11g R2(11.2.0.4) RAC 数据文件路径错误解决--ORA-01157 ORA-01110: 数据文件

    Oracle 11g R2(11.2.0.1) RAC  数据文件路径错误解决--ORA-01157 ORA-01110: 数据文件 oracle 11g R2(11.2.0.4) rac--scan ...

  6. ORACLE 11GR2 RAC的网络规划解析

    在ORACLE 11gR2中,安装RAC发生了显著变化.在10g以及11gR1的时代,安装RAC的步骤是先安装CRS,再安装DB,而到了11gR2的时代,crs与asm被集成在一起,合称为GRID,必 ...

  7. 【故障•监听】TNS-12518、TNS-00517和 Linux Error:32:Broken pipe

    [故障|监听]TNS-12518.TNS-00517和 Linux Error:32:Broken pipe 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱 ...

  8. Troubleshooting ORA-12547 TNS: Lost Contact (Doc ID 555565.1)

    Troubleshooting ORA-12547 TNS: Lost Contact (Doc ID 555565.1) This error can occur in following scen ...

  9. oracle RAC的VIP和scan

    我们都知道Oracle RAC中每个节点都有一个虚拟IP,简称VIP,与公网IP在同一个网段. 没有VIP时,Oracle客户端是靠"TCP/IP协议栈超时"来判断服务器故障.而T ...

随机推荐

  1. 基本上,把switch,用设计模式代替,肯定是bug和过度设计。想想,本来修改一个文件几行代码可以解决的问题,变成修改3-6个类才能实现一样的功能。不是傻是什么?

    那些迷信设计模式的人,来修改一下这个方法吧.看看你最终的代码膨胀为几倍... public virtual PasswordChangeResult ChangePassword(ChangePass ...

  2. js搜索框 js仿百度搜索 js下拉框 jQuery.Autocomplete使用

    做了一个网站,需要根据文本框的输入模糊搜索数据库内容给出提示供用户选择,就找到了jQuery.Autocomplete 效果如下图: 该插件托管在github上,具体地址:https://github ...

  3. 排序算法FOUR:堆排序HeapSort

    /** *堆排序思路:O(nlogn) * 用最大堆,传入一个数组,先用数组建堆,维护堆的性质 * 再把第一个数与堆最后一个数调换,因为第一个数是最大的 * 把堆的大小减小一 * 再 在堆的大小上维护 ...

  4. think完全还原原形的 SQL

    $dd     =   Db::getInstance(); //实例连接数据库$sql = "SELECT * FROM `yezi_friendlinks`"; // SQL$ ...

  5. C# 解析带前缀的Xml节点内容

    一般的xml文件相信大家都会解析了,但是遇到有命名空间的带前缀的xml,对于新手可能会有点问题.我这里在论坛解答的时候就遇到过一题,见怎么获取XML节点里面的内容,在线求教.这里给大家演示一下. 他的 ...

  6. sql修改表结构、临时表应用

    alter table dbo.P_ZPROMOTION_DOC_ITEMS_TEMP alter column MCRANK  varchar(20); 方法一: use testdb --创建局部 ...

  7. rar压缩文件下载

    //string fileName = "ceshi.rar";//客户端保存的文件名         //string filePath = Server.MapPath(&qu ...

  8. Chrome 浏览器各版本下载大全

    随着最近64位版本的 Chrome 浏览器正式版的推出,Chrome 浏览器再次受到广大浏览迷的重点关注,今天我们就整理一下各版本的 Chrome 浏览器 32位及64位的下载地址,方便各位浏览迷选择 ...

  9. Python 列表实现字典的get功能

    字典有一个很好用的方法,就是get,既可以预防KeyError异常,也可以为不存在的key设置一个默认的value 例如: v=d.get('k','default') 而列表没有一个类似的方法,如果 ...

  10. CSS 背景颜色

    颜色背景 CSS中背景颜色由background-color决定,这里的背景颜色会渲染padding和content,不会渲染border和margin部分. 在css3中可以通过background ...