好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

AboutOracle11gR2GridInfrastructureSingleClientAcce

Oracle 11gR2Grid Infrastructure (CRS) 中引入了 Single Client Access Name (SCAN) 来简化客户端对数据库服务的访问,本文将详细说明 SCAN 的含义及其工作原理。 SCAN 概念 Single client access name (SCAN) 是提供给所有客户端用于连接集群的虚拟主机名

Oracle 11gR2Grid Infrastructure (CRS) 中引入了 Single Client Access Name (SCAN) 来简化客户端对数据库服务的访问,本文将详细说明 SCAN 的含义及其工作原理。

SCAN 概念

Single client access name (SCAN) 是提供给所有客户端用于连接集群的虚拟主机名称(与 10g 和 11g R1 中的 vip 主机名称相对应)。 SCAN 是 DNS 或 Grid Naming Service (GNS) 中注册到 1-3 个 IP 地址的一个域名。 默认情况下, SCAN 名称与集群的名称相同,且该名称在同一企业内必须唯一。 SCAN 的默认值基于本地节点的名称。 SCAN 名称的长度最少 1 个字符,最多 15 个字符, 必须包含字母和数字,不得以数字开头,可以包含连字符 (-) 。如果要使用长度超过 15 字符的 SCAN ,请在安装 Grid Infrastructure 时选择“ Advanced installation ”选项。 要想成功安装 Grid Infrasture , SCAN 必须至少解析成一个 IP 地址。 SCAN VIP 地址必须与 virtual IP 地址和 public IP 地址位于同一子网。 Oracle 强烈建议不要再 hosts 文件中配置 SCAN VIP 地址。如果使用 hosts 文件来解析 SCAN 主机名,则该 SCAN hostname 只能解析成一个 SCAN IP 地址。 如果使用 hosts 文件来解析 SCAN 主机名,则在 Grid Infrastructure 安装结束时会遇到类似如下 Cluster Verification Utility 故障。

Installation log -$ORACLE_BASE/oraInventory/logs/installActions{$TIMESTAMP}.log

INFO: PRVG-1101 : SCANname "cluscan.us.oracle测试数据" failed to resolve

INFO: ERROR:

INFO: PRVF-4664 : Found inconsistent name resolution entries for SCAN name "cluscan.us.oracle测试数据"

INFO: ERROR:

INFO: PRVF-4657 : Name resolution setup check for"scanclunm" (IP address: 10.4.0.202) failed

OR

PRCS-1016 : Failed to resolve Single Client Access Namecluscan.us.oracle测试数据

出于高可用性和可扩展性的考虑, Oracle 推荐配置使用 DNS 循环解析将 SCAN 解析成三个地址。 因为 SCAN 是与整个集群而不是特定的节点关联,使用 SCAN 可以再无需重新配置客户端的情况下方便地从集群添加或删除节点。 SCAN 还增强了数据库的位置无关性,使得客户端配置部再依赖于运行特定数据库的节点。 客户端仍然可以继续使用之前版本的方法来访问集群,不过 O racle 推荐客户端使用 SCAN 来访问集群。使用 SCAN 的客户端也可以使用 EZCONNECT 方式来访问集群。 Grid Infrastructure 除了启动所有节点上的本地监听程序 LISTENER 来监听本地的 VIP 外,还会启动 SCAN listener LISTENER_SCAN1 (一个集群中最多 3 个)来监听 SCAN VIP ; Oracle Database 11gR2 默认情况下会将 local_listener 设置成 local LISTENER ,将 remote_listener 设置为 SCAN listener 。 SCAN listener will be running off GRID_HOME, and by default, in 11gR2 local listener will be running off GRID_HOME as well.

SCAN 相关的常见问题

如何配置 SCAN 和 SCAN listener ?

在“ Typical installation ”过程中,程序会提示您确认默认的 Single Client Access Name (SCAN) 。如果您更改默认的 SCAN ,则您要使用的 SCAN 名称必须保持唯一性。

如果 SCAN 名称解析成一个 IP 地址,则 root 脚本 (root.sh or rootupgrade.sh) 将根据 SCAN 名称解析的 IP 地址数量来创建 SCAN VIP 资源 (ora.scan1.vip) 以及相应 SCAN listener 资源 (ora.LISTENER_SCAN1.lsnr) 的数量。例如,如果 SCAN 名称可以解析为 2 个 IP 地址,则将 root 脚本就会创建两个 SCAN VIP 资源和两个相应的 SCAN listener 资源。

SCAN VIP 及相应的 SCAN listener 成对工作,当 SCAN VIP failover 到其他节点,则相应的 SCAN 监听程序也会 failover 到同一节点。

当 SCAN VIP failover 发生时,始终会选择运行 SCAN VIP 最少的节点,例如,在一个 4 节点的集群中,如果 SCAN VIP 运行在节点、节点 2 和节点 3 上,则当节点 3 down 掉时,节点 3 上的 SCAN VIP 及相应的 SCAN listener 就会 failover 到节点 4 上,因为其他两个节点的每个节点上已经运行了一个 SCAN VIP 。

我们还可以使用 “ srvctl ” 来添加 / 修改 SCAN vip 和 listener 。

是否仍然需要在每个节点上配置 locallistener ?

回答是“是”,我们仍然需要在每个节点配置独立的 local listener 。 SCAN listener 并没有取代每个节点上的 local listener 。

在 11g R2 的 GI 中,集群中的所有节点上会运行 3 个新的 scan listener ,如果集群节点超过 3 个,则只会在其中 3 个节点上运行 SCAN listener ,无论集群有多少节点,最多也只会有 3 个 scan listener 。数据库通过 remote _listener 初始化参数注册到 SCAN listener 中。如果集群中任意一个 scan listener 挂掉,都会在一个新的节点上自动重启。

SCAN 的工作原理

在客户端提交请求时,在 SCAN VIP 地址及端口上进行监听的 SCAN listener 就会代表客户端建立连接。因为集群上的所有服务都已注册到 SCAN listener 中, SCAN listener 就会将负载最少的节点(每个 scan listener 会实时更新集群的负载统计信息)上的 local listener 的地址返回给客户端。最后,客户端就与通过返回的提供服务的节点上的 local listener 与服务建立连接。所有这些操作对于客户端来说都会透明的,客户端无需进行任何明确的配置。

$ SRVCTL STATUSSCAN_LISTENER

SCAN ListenerLISTENER_SCAN1 is enabled

SCAN ListenerLISTENER_SCAN2 is enabled

SCAN ListenerLISTENER_SCAN3 is enabled

可否用 '/etc/hosts' 来解析 SCAN 而不用 DNS 或 GNS ?

Oracle 强烈建议不要在 hosts 文件中配置 SCAN VIP 地址。但是可以使用 hosts 文件来解析 SCAN 名称,只不过只能解析成一个 SCAN IP 地址。

如果使用 hosts 文件来解析 SCAN 名称,则在安装结束时会遇到 ClusterVerification Utility 失败错误,详细信息请见 metalink 文章 NOTE 887471.1 。

可否使用之前的连接方式( VIP )来进行客户端连接?

客户端仍旧可以使用之前版本的连接方式( VIP )来访问集群。

Oracle 强烈建议客户端使用 SCAN 来访问集群。使用 SCAN 的客户端也可以 EZCONNECT 方式来访问集群。

是否必须要使用 SCAN ?

强烈建议而已,并非必须。

是否支持删除 SCAN ?

SCAN Oracle 11gR2 Grid Infrastructure 的一个组件,不支持删除 SCAN 。

Sample TNS entry for SCAN

TEST.ORACLE.COM =

(DESCRIPTION=

(ADDRESS=(PROTOCOL=tcp)(HOST=SCAN-TEST.ORACLE.COM)(PORT=1521))

(CONNECT_DATA=(SERVICE_NAME=11GR2TEST.ORACLE.COM))

)

Sample TNS Entry without SCAN

TEST.ORACLE.COM =

(DESCRIPTION=

(ADDRESS_LIST=

(ADDRESS=(PROTOCOL=tcp)(HOST=TEST1-vip.ORACLE.COM)(PORT=1521))

(ADDRESS=(PROTOCOL=tcp)(HOST=TEST2-vip.ORACLE.COM)(PORT=1521))

)

(CONNECT_DATA=(SERVICE_NAME=11GR2TEST.ORACLE.COM))

)





作者:xiangsir

QQ:444367417

MSN:xiangsir@hotmail测试数据

查看更多关于AboutOracle11gR2GridInfrastructureSingleClientAcce的详细内容...

  阅读:41次