oracle数据库根据名字,Oracle的db_name,service_names,instance_name等参数解析

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个字符。

436f8911fa60e1bf2e08945e0045c3e1.png

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参数前,如下图所示

b536ea0585faa029aedbb0d67c0d0005.png修改instance_name参数后:

45a2ab547d5424993f84a28366a9bb56.png两张图对比可以知道,instance_name在注册监听时起到指定名字的作用。

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

service_names:

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

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

9d6b267ff1ecc32c611a715782eabc34.png修改service_names后,监听中多出了设置的service名:

c383eb02788d19eaca4c0046a862191a.png使用新设置的服务名也可以连接到数据库:

d1b6f47fbd722e53f44cc361fe553d7b.png

oracle_sid:

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

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

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

e35718175674e656769940290c37d6a4.png关闭数据库,修改ORACLE_SID=mydb,同样可以启动数据库,不过需要手动指定参数文件,生成的进程以mydb标识。

25477bca50e969609484fd5ccba162d0.png即使进程都是与mydb相关,但数据库名字和监听的配置仍然为test

69159a4c8fa43d2a1f4baf3a0c0b428b.png

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

6b90a8cbf3dc507cd5648c11bd101d4e.png

tnsnames.ora中的service_name和sid:

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

listener.ora中的sid_name和global_dbname:

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

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

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值