阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle的db_name,service_names,instance_name等参数解析

128次阅读
没有评论

共计 2422 个字符,预计需要花费 7 分钟才能阅读完成。

Oracle 中有很多与名字相关的参数,有时会让人觉得迷惑,这个参数都有什么作用,它们之间的区别又是什么呢?

下面我们先来看一看都有哪些参数与名字相关

  • 参数文件中有 db_name,instance_name,service_names,db_unique_name

  • 环境变量中有 oracle_sid

  • 在 listener.ora 中有 sid_name,global_dbname(静态注册的情况下)

  • 在 tnsnames.ora 中有 service_name,sid

它们各有什么含义呢,我们来一一介绍:

db_name:

       对一个数据库 (Oracle database) 的唯一标识,这种表示对于单个数据库时足够的,但是对于分布

式数据库,可能存在各个数据库的名字可能一样,db_domian 也就是为了解决这一问题,这样数据库的 标识是由 db_name 和 db_domain 两个参数共同决定。类似于互联网上的机器名管理,用 db_name.db_domain 来表示一个数据库,并将该数据库的名称称为 global_name。db_name 只能由字母 / 数字,’_’,’#’,’$’ 组成,而且最多 8 个字符。

Oracle 的 db_name,service_names,instance_name 等参数解析

DB_UNIQUE_NAME:

和 db_name 不一样的作用,用于指定数据库的全局唯一名,比如 DG 中的物理备库与主库有相同的 db_name 和 db_domain。需要用 db_unique_name 来进行区别。可以设置 30 个字符,大小写不敏感,由字母 / 数字,’_’,’#’,’$’ 组成。DB_UNQUIE_NAME 的会影响到 Service_names,也会影响到动态监听的时候的 service_name。

instance_name:

实例唯一标识符,如 RAC 环境,存在多实例情况下,用 instance_name 区别每个实例。用来设置在动态监听中注册的 instance_name,对应的如果在 tnsnames.ora 中使用 SID 连接时,需要与之做对应。

未修改 instance 参数前,如下图所示

Oracle 的 db_name,service_names,instance_name 等参数解析修改 instance_name 参数后:

Oracle 的 db_name,service_names,instance_name 等参数解析两张图对比可以知道,instance_name 在注册监听时起到指定名字的作用。

此外一些包含 instance_name 或 inst_name 列的动态性能视图是从环境变量 ORACLE_SID(而不是这个参数)来推断的。

service_names:

用于设置在监听中注册的服务名。对应的做 tnsnames.ora 中如果使用 SERVICE_NAME 连接时需要与之对应。

修改 service_names 之前,service_names 与监听中的 service 一致:

Oracle 的 db_name,service_names,instance_name 等参数解析修改 service_names 后,监听中多出了设置的 service 名:

Oracle 的 db_name,service_names,instance_name 等参数解析使用新设置的服务名也可以连接到数据库:

Oracle 的 db_name,service_names,instance_name 等参数解析

oracle_sid:

实例标识符,以环境变量形式存在,同时用于对应共享内存段.Oracle 实例是由 SGA 和一组后台进程组成的,实例的创建和启动需要一个参数文件,而参数文件的名称就是由 ORACLE_SID 决定的。对于 init 文件,缺省的文件名称是 init<ORACLE_SID>.ora,对于 spfile 文件,缺省的文件名称是 spfile<ORACLE_SID>.ora。设置不同的 ORACLE_SID 值,就可以默认使用不同的参数文件启动不同的数据库实例。

也就是说 ORACLE_SID 决定本地启动的数据库实例的实例名,只要有对应的 init<ORACLE_SID>.ora 或 spfile<ORACLE_SID>.ora 就可以启动,也可以在 startup 中指定 pfile 启动都是可以的,只要参数文件中设置的其他参数可以启动一个数据库就行。

正常情况下 ORACLE_SID=test,启动数据库如下图,生成的进程以 test 标识。

Oracle 的 db_name,service_names,instance_name 等参数解析关闭数据库,修改 ORACLE_SID=mydb,同样可以启动数据库,不过需要手动指定参数文件,生成的进程以 mydb 标识。

Oracle 的 db_name,service_names,instance_name 等参数解析即使进程都是与 mydb 相关,但数据库名字和监听的配置仍然为 test

Oracle 的 db_name,service_names,instance_name 等参数解析

对应动态性能视图里的 instance_name 和 inst_name 也发生了变化:

Oracle 的 db_name,service_names,instance_name 等参数解析

tnsnames.ora 中的 service_name 和 sid:

tnsnames.ora 中的 service_name 和 sid 分别要连接的远程数据库在监听中注册的 service 和 instance 相对应。

test =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.2)(PORT = 1522))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SID = test)
    )
  )
    
test =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.2)(PORT = 1522))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = test)
    )
  )

listener.ora 中的 sid_name 和 global_dbname:

这两个参数用于使用静态注册监听时识别为哪个实例静态注册。

SID_LIST_LISTENER=
  (SID_LIST=
    (SID_DESC=
      (GLOBAL_DBNAME=orcl)
      (ORACLE_HOME=/u02/app/oracle/product/11.2.4/db1)
      (SID_NAME=orcl)))

以上内容为我自己的整理与总结,有不对的地方还请大神指点。

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/143636.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2422字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中