tnsnames.ora中设置SID有意义吗?

[复制链接]
查看11 | 回复7 | 2011-5-7 01:45:08 | 显示全部楼层 |阅读模式
在listener.ora中描述如下
SID_LIST_TEST9 =
(SID_LIST =
(SID_DESC =
(SID_NAME = orcl)
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
)
)
TEST9 =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = thinker)(PORT = 1522))
)
)
)
-------------------------
在客户端的tnsnames.ora中,配置如下
ORCL2 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = thinker)(PORT = 1522))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SID = orcl)
)
)
---------------------------

我有2个疑问:
1、tnsnames.ora中,发现SID = orcl也可以写作SERVICE_NAME = orcl,客户端照样能连接到数据库,请问2种写法有什么区别?
2、既然listener.ora中,每个IP端口对应都要对应一个SID_NAME,那么客户端的tnsnames.ora中指明SID岂不是多余?oracle公司是怎么考虑的?有谁能告诉我这样做的合理性?
谢谢
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
1.service_name 的含义可以看文档,rac中经常用,一个instance可以多个service_name.
2.既然listener.ora中,每个IP端口对应都要对应一个SID_NAME ----不明白lz的意思,从字面上看,lz理解的是完全错误的,可以google一下静态监听
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
1.还是先找书看看sid和service得区别
2.一个listener可以注册多个instance,可以看看oracle network service...
有想法是好的,不过,先看看书再想也许会更好


回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
一、什么是注册?
  注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。
  在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)
  相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。
  二、静态注册
  静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。
  静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。
  采取静态注册方法时,listener.ora中的内容如下:
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(PROGRAM = extproc)
)
(SID_DESC =
(GLOBAL_DBNAME =orcl)
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(SID_NAME =orcl)
)
(SID_DESC =
(GLOBAL_DBNAME =orcl1)
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(SID_NAME =orcl)
)
该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:orcl和orcl1
  三、动态注册
  动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和服务动态注册到listener中。
  首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter service_names 和show parameter instance_name可以查看这两个参数的值。
  注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取init.ora文件中的db_name的值。
  注册到监听器中的服务值从init.ora文件中的参数service_names取得。如果该参数没有设定值,数据库将拼接init.ora文件中的 db_name和db_domain的值来注册自己。如果选择提供service_names值,您可以使用完全限定的名称(比如 orcl.oracle.com)或缩写的名称(比如orcl)。如果选择缩写的名称并设置了db_domain参数,注册到监听器中的服务将是 service_name值和db_domain值的拼接。例如下面的设置将导致服务orcl.oracle.com被注册到监听器中:
db_domain=oracle.com
service_names=orcl ;
  采取动态注册方法时,listener.ora中的内容如下:
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(PROGRAM = extproc)
)
)
  可选择的是,您可以在service_names参数中指定多个服务值,值之间用逗号格开,这对于共享服务器配置是很有用的。
  动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是TCP),如果需要向非默认监听注册,则需要配置local_listener参数!
  如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况 下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没有显式设置 service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。
  为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。因为如果监听器在数据库运行过程中要重新启 动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的 时间之内完成动态注册。
  四、查询某服务是静态注册还是动态注册
  可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。
  实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。
  动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都会动态地从 监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退 (fallback)和负载平衡。
)
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
多谢zergduan 和版主的醍醐灌顶,书我看了几本,可惜没搞明白。现在清楚了,谢谢
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
谢谢oracular 提供的资料
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
我还没太理解,借这个帖子在问一句哈
在下边列出了listener.ora 和 lsnrctl status 的输出.
依照oraclular给出的文档,我不明白的有两点:
1.我觉得配置文件里只配置了静态注册,那动态的注册是怎么出来的?
2.我发现数据库里边配置的service_name和lsnrctl status输出的service_name不一样,why?

# Generated by Oracle configuration tools.
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = pnsgdev1db1)(PORT = 1521))
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
)

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = CUD)
(ORACLE_HOME = /opt/oracle/product/cud/10.2)
)
(SID_DESC =
(SID_NAME = PND)
(ORACLE_HOME = /opt/oracle/product/pnd/10.2)
)
(SID_DESC =
(SID_NAME = TRD)
(ORACLE_HOME = /opt/oracle/product/trd/10.2)
)

)

Services Summary...
Service "CUD" has 2 instance(s).
Instance "CUD", status UNKNOWN, has 1 handler(s) for this service...
Instance "cud", status READY, has 1 handler(s) for this service...
Service "PND" has 2 instance(s).
Instance "PND", status UNKNOWN, has 1 handler(s) for this service...
Instance "pnd", status READY, has 1 handler(s) for this service...
Service "TRD" has 2 instance(s).
Instance "TRD", status UNKNOWN, has 1 handler(s) for this service...
Instance "trd", status READY, has 1 handler(s) for this service...
Service "cudXDB" has 1 instance(s).
Instance "cud", status READY, has 1 handler(s) for this service...
Service "cud_XPT" has 1 instance(s).
Instance "cud", status READY, has 1 handler(s) for this service...
Service "pndXDB" has 1 instance(s).
Instance "pnd", status READY, has 1 handler(s) for this service...
Service "pnd_XPT" has 1 instance(s).
Instance "pnd", status READY, has 1 handler(s) for this service...
Service "trdXDB" has 1 instance(s).
Instance "trd", status READY, has 1 handler(s) for this service...
Service "trd_XPT" has 1 instance(s).
Instance "trd", status READY, has 1 handler(s) for this service...

SQL> show parameter service_name
NAME
TYPEVALUE
------------------------------------ ----------- ------------------------------
service_names
stringcud
SQL> show parameter instance_name
NAME
TYPEVALUE
------------------------------------ ----------- ------------------------------
instance_name
stringcud
回复

使用道具 举报

千问 | 2011-5-7 01:45:08 | 显示全部楼层
顶一下
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行