찾다
데이터 베이스MySQL 튜토리얼About Oracle 11gR2 Grid Infrastructure Single Client Access

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

Oracle11gR2Grid 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 InfrastureSCAN必须至少解析成一个 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.com" failed to resolve

INFO: ERROR:

INFO: PRVF-4664 : Found inconsistent name resolution entries for SCAN name "cluscan.us.oracle.com"

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.com

 

 

  • 出于高可用性和可扩展性的考虑, Oracle推荐配置使用 DNS循环解析将 SCAN解析成三个地址。
  • 因为 SCAN是与整个集群而不是特定的节点关联,使用 SCAN可以再无需重新配置客户端的情况下方便地从集群添加或删除节点。SCAN还增强了数据库的位置无关性,使得客户端配置部再依赖于运行特定数据库的节点。
  • 客户端仍然可以继续使用之前版本的方法来访问集群,不过 Oracle推荐客户端使用 SCAN来访问集群。使用SCAN的客户端也可以使用 EZCONNECT方式来访问集群。
  • Grid Infrastructure除了启动所有节点上的本地监听程序 LISTENER来监听本地的VIP外,还会启动SCAN listener LISTENER_SCAN1(一个集群中最多3个)来监听SCAN VIPOracle Database11gR2默认情况下会将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相关的常见问题

 

如何配置 SCANSCAN 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 VIPfailover发生时,始终会选择运行SCAN VIP最少的节点,例如,在一个 4节点的集群中,如果 SCAN VIP运行在节点、节点2和节点3上,则当节点 3 down 掉时,节点3上的SCAN VIP 及相应的SCAN listener就会 failover到节点4上,因为其他两个节点的每个节点上已经运行了一个SCAN VIP

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

 

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

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

 

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

 

SCAN的工作原理

About Oracle 11gR2 Grid Infrastructure Single Client Access

 

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

 

$ SRVCTL STATUSSCAN_LISTENER

SCAN ListenerLISTENER_SCAN1 is enabled

SCAN listenerLISTENER_SCAN1 is running on node TEST1

SCAN ListenerLISTENER_SCAN2 is enabled

SCAN listenerLISTENER_SCAN2 is running on node TEST2

SCAN ListenerLISTENER_SCAN3 is enabled

SCAN listenerLISTENER_SCAN3 is running on node TEST3

 

可否用 '/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.com


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL에서 데이터베이스 업그레이드를 어떻게 처리합니까?MySQL에서 데이터베이스 업그레이드를 어떻게 처리합니까?Apr 30, 2025 am 12:28 AM

MySQL 데이터베이스를 업그레이드하는 단계에는 다음이 포함됩니다. 1. 데이터베이스 백업, 2. 현재 MySQL 서비스 중지, 3. 새 버전의 MySQL 설치, 4. 새 버전의 MySQL 서비스 시작, 5. 데이터베이스 복구. 업그레이드 프로세스 중에 호환성 문제가 필요하며 Perconatoolkit과 같은 고급 도구를 테스트 및 최적화에 사용할 수 있습니다.

MySQL에 사용할 수있는 다른 백업 전략은 무엇입니까?MySQL에 사용할 수있는 다른 백업 전략은 무엇입니까?Apr 30, 2025 am 12:28 AM

MySQL 백업 정책에는 논리 백업, 물리적 백업, 증분 백업, 복제 기반 백업 및 클라우드 백업이 포함됩니다. 1. 논리 백업은 MySQLDump를 사용하여 데이터베이스 구조 및 데이터를 내보내며 소규모 데이터베이스 및 버전 마이그레이션에 적합합니다. 2. 물리적 백업은 데이터 파일을 복사하여 빠르고 포괄적이지만 데이터베이스 일관성이 필요합니다. 3. 증분 백업은 이진 로깅을 사용하여 변경 사항을 기록합니다. 이는 큰 데이터베이스에 적합합니다. 4. 복제 기반 백업은 서버에서 백업하여 생산 시스템에 미치는 영향을 줄입니다. 5. AmazonRDS와 같은 클라우드 백업은 자동화 솔루션을 제공하지만 비용과 제어를 고려해야합니다. 정책을 선택할 때 데이터베이스 크기, 가동 중지 시간 허용 오차, 복구 시간 및 복구 지점 목표를 고려해야합니다.

MySQL 클러스터링이란 무엇입니까?MySQL 클러스터링이란 무엇입니까?Apr 30, 2025 am 12:28 AM

mysqlclusteringenhancesdatabaserobustness andscalabilitydaturedingdataacrossmultiplenodes.itusesthendbenginefordatareplicationandfaulttolerance, highavailability를 보장합니다

MySQL의 성능을 위해 데이터베이스 스키마 설계를 어떻게 최적화합니까?MySQL의 성능을 위해 데이터베이스 스키마 설계를 어떻게 최적화합니까?Apr 30, 2025 am 12:27 AM

MySQL에서 데이터베이스 스키마 설계 최적화는 다음 단계를 통해 성능을 향상시킬 수 있습니다. 1. 인덱스 최적화 : 공통 쿼리 열에서 인덱스 생성, 쿼리의 오버 헤드 균형 및 업데이트 삽입. 2. 표 구조 최적화 : 정규화 또는 정상화를 통한 데이터 중복성을 줄이고 액세스 효율을 향상시킵니다. 3. 데이터 유형 선택 : 스토리지 공간을 줄이기 위해 Varchar 대신 Int와 같은 적절한 데이터 유형을 사용하십시오. 4. 분할 및 하위 테이블 : 대량 데이터 볼륨의 경우 파티션 및 하위 테이블을 사용하여 데이터를 분산시켜 쿼리 및 유지 보수 효율성을 향상시킵니다.

MySQL 성능을 어떻게 최적화 할 수 있습니까?MySQL 성능을 어떻게 최적화 할 수 있습니까?Apr 30, 2025 am 12:26 AM

tooptimizemysqlperformance, followthesesteps : 1) 구현 properIndexingToSpeedUpqueries, 2) useExplaintoAnalyzeanDoptimizeQueryPerformance, 3) AdvertServerConfigUrationSettingstingslikeInnodb_buffer_pool_sizeandmax_connections, 4) uspartOflEtOflEtOflestoI

데이터 처리 및 계산에 MySQL 기능을 사용하는 방법데이터 처리 및 계산에 MySQL 기능을 사용하는 방법Apr 29, 2025 pm 04:21 PM

MySQL 기능은 데이터 처리 및 계산에 사용될 수 있습니다. 1. 기본 사용에는 문자열 처리, 날짜 계산 및 수학 연산이 포함됩니다. 2. 고급 사용에는 복잡한 작업을 구현하기 위해 여러 기능을 결합하는 것이 포함됩니다. 3. 성능 최적화를 위해서는 WHERE 절에서 기능 사용 및 GroupBy 및 임시 테이블 사용을 피해야합니다.

MySQL에 데이터를 일괄 삽입하는 효율적인 방법MySQL에 데이터를 일괄 삽입하는 효율적인 방법Apr 29, 2025 pm 04:18 PM

MySQL에 데이터 삽입을위한 효율적인 방법은 다음과 같습니다. 1. InsertInto 사용 ... 값 구문 사용 ... 값 구문, 2. 트랜잭션 처리 사용, 3. 트랜잭션 처리 사용, 4. 배치 크기 조정, 5. 인덱스 비활성화, 6. Insertignore 또는 Insert ... ondupliceKeyUpdate를 사용하여 데이터베이스 작동 효율성을 크게 향상시킬 수 있습니다.

MySQL 테이블에 필드를 추가 및 삭제하는 단계MySQL 테이블에 필드를 추가 및 삭제하는 단계Apr 29, 2025 pm 04:15 PM

MySQL에서는 altertabletable_nameaddcolumnnew_columnvarchar (255) 이후에 필드를 추가하여 altertabletable_namedropcolumncolumn_to_drop을 사용하여 필드를 삭제합니다. 필드를 추가 할 때는 쿼리 성능 및 데이터 구조를 최적화하기위한 위치를 지정해야합니다. 필드를 삭제하기 전에 작업이 돌이킬 수 없는지 확인해야합니다. 온라인 DDL, 백업 데이터, 테스트 환경 및 저하 기간을 사용하여 테이블 구조 수정은 성능 최적화 및 모범 사례입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.