ORACLE中的db_name,service_names,instance_name,oracle_sid,global_dbname

简介:

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

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

wKiom1kR0bPgM_DCAACu-A8n23A349.png修改instance_name参数后:

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

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

service_names:

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

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

wKiom1kR0-OyTKrrAACxESUwgzw768.png修改service_names后,监听中多出了设置的service名:

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

wKiom1kR1DugUYeTAAAcyN9GWZc178.png

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标识。

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

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

wKioL1kR2BWBhwBDAACmHKou53Y532.png

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

wKiom1kR5F-yRb_pAAAL1Y1ukj0625.png

tnsnames.ora中的service_name和sid:

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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:

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

1
2
3
4
5
6
SID_LIST_LISTENER=
   (SID_LIST=
     (SID_DESC=
       (GLOBAL_DBNAME=orcl)
       (ORACLE_HOME=/u02/app/oracle/product/11.2.4/db1)
       (SID_NAME=orcl)))

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


参考:http://blog.sina.com.cn/s/blog_616b428f0100iwro.html






      本文转自hbxztc 51CTO博客,原文链接:http://blog.51cto.com/hbxztc/1923899,如需转载请自行联系原作者



相关文章
|
Oracle 网络协议 关系型数据库
|
关系型数据库
oracle db_unnqiue_name db_name sid_name instance_name service_name
TNS:net service name is incorrectly specified
673 0
|
Oracle 关系型数据库 数据库
【转】ORACLE_SID、INSTANCE_NAME、DB_NAME
文章转自:http://www.blogjava.net/herongxin/archive/2011/05/31/351414.html 【一】对ORACLE_SID的理解 Oracle中SID的作用类似于一个“开关变量”---引导Oracle在实例启动时如何去默认位置下读取适当的参数文件并加载,以正确启动实例。
1086 0
|
SQL Oracle 关系型数据库
ORACLE_SID、DB_NAME、INSTANCE_NAME、DB_DOMIAN、GLOBAL_NAME
--============================================================= -- ORACLE_SID、DB_NAME、INSTANCE_NAME、DB_DOMIAN、GLOBAL_NAME -...
906 0
|
6天前
|
Oracle 关系型数据库 MySQL
实时计算 Flink版操作报错合集之采集oracle的时候报ORA-65040:不允许从可插入数据库内部执行该操作如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
29 3
|
9天前
|
SQL Oracle 安全
Oracle11g更改数据库名(详细教程)
Oracle11g更改数据库名(详细教程)
17 1
|
1天前
|
Oracle 关系型数据库 数据库
实时计算 Flink版产品使用合集之采集Oracle数据库时,归档日志大小暴增的原因是什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStreamAPI、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
1天前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用合集之从Oracle数据库同步数据时,checkpoint恢复后无法捕获到任务暂停期间的变更日志,如何处理
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStreamAPI、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
1天前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用合集之如何SQL同步数据到Oracle数据库中
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStreamAPI、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。