Oracle实例名,服务名等概念区别与联系
数据库名、实例名、数据库域名、全局数据库名、服务名 ,
这是⼏个令很多初学者容易混淆的概念。相信很多初学者都与我⼀样被标题上这些个概念搞得⼀头雾⽔。我们现在就来把它们弄个明⽩。⼀、数据库名
什么是数据库名?
数据库名就是⼀个数据库的标识,就像⼈的⾝份证号⼀样。他⽤参数DB_NAME表⽰,如果⼀台机器上装了多个数据库,那么每⼀个数据库都有⼀个数据库名。在数据库安装或创建完成之后,参数DB_NAME被写⼊参数⽂件之中。格式如下:
DB_NAME=myorcl
...
在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很⿇烦。因为,数据库名还被写⼊控制⽂件中,控制⽂件是以 ⼆进制型式存储的,⽤户⽆法修改控制⽂件的内容。假设⽤户修改了参数⽂件中的数据库名,即修改DB_NAME 的值。但是在Oracle启动时,由于参数⽂ 件中的DB_NAME与控制⽂件中的数据库名不⼀致,导致数据库启动失败,将返回ORA-01103错误。
数据库名的作⽤
数据库名是在安装数据库、创建新的数据库、创建数据库控制⽂件、修改数据结构、备份与恢复数据库时都需要使⽤到的。
有很多Oracle安装⽂件⽬录是与数据库名相关的,如:
winnt: d:\oracle\product\10.1.0\oradata\DB_NAME\...
Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/...
pfile:
winnt: d:\oracle\product\10.1.0\admin\DB_NAME\a
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$a
跟踪⽂件⽬录:
winnt: /home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...
另外,在创建数据时,careate database命令中的数据库名也要与参数⽂件中DB_NAME参数的值⼀致,否则将产⽣错误。
同样,修改数据库结构的语句alter database, 当然也要指出要修改的数据库的名称。
如果控制⽂件损坏或丢失,数据库将不能加载,这时要重新创建控制⽂件,⽅法是以nomount⽅式启动实例,然后以create controlfile命令创建控制⽂件,当然这个命令中也是指指DB_NAME。
还有在备份或恢复数据库时,都需要⽤到数据库名。
总之,数据库名很重要,要准确理解它的作⽤。
查询当前数据名
⽅法⼀:select name from v$database;
⽅法⼆:show parameter db
⽅法三:查看参数⽂件。
修改数据库名
前⾯建议:应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是⼀件⽐较复杂的事情。那么现在就来说明⼀下,如何在已创建数据之后,修改数据库名。步骤如下:
1.关闭数据库。
2.修改数据库参数⽂件中的DB_NAME参数的值为新的数据库名。
3.以NOMOUNT⽅式启动实例,修建控制⽂件(有关创建控制⽂件的命令语法,请参考oracle⽂档)
⼆、数据库实例名
什么是数据库实例名?
数据库实例名是⽤于和操作系统进⾏联系的标识,就是说数据库和操作系统之间的交互⽤的是数据库实例名。实例名也被写⼊参数⽂件中,该参数为instance_name,在winnt平台中,实例名同时也被写⼊注册表。
数据库名和实例名可以相同也可以不同。
在⼀般情况下,数据库名和实例名是⼀对⼀的关系,但如果在oracle并⾏服务器架构(即oracle实时应⽤集)中,数据库名和实例名是⼀对多的关系。这⼀点在第⼀篇中已有图例说明。
查询当前数据库实例名
⽅法⼀:select instance_name from v$instance;
⽅法⼆:show parameter instance
⽅法三:在参数⽂件中查询。
数据库实例名与ORACLE_SID
虽然两者都表⽰oracle实例,但两者是有区别的。instance_name是oracle数据库参数。⽽ORACLE_SID是操作系统的环境变 量。
ORACLD_SID⽤于与操作系统交互,也就是说,从操作系统的⾓度访问实例名,必须通过ORACLE_SID。在winnt平台, ORACLE_SID 还需存在于注册表中。
且ORACLE_SID必须与instance_name的值⼀致,否则,你将会收到⼀个错误,在unix平台,是“ORACLE not available”,在winnt平台,是“TNS:协议适配器错误”。
数据库实例名与⽹络连接
数据库实例名除了与操作系统交互外,还⽤于⽹络连接的oracle服务器标识。当你配置oracle主机连接串的时候,就需要指定实例名。当然8i以后版本的⽹络组件要求使⽤的是服务名SERVICE_NAME。这个概念接下来说明 。
三、数据库域名
什么是数据库域名?
在分布式数据库系统中,不同版本的数据库服务器之间,不论运⾏的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进⾏远程复制,数据库域名主要⽤于oracle分布式环境中的复制。举例说明如:
全国交通运政系统的分布式数据库,其中:
福建节点: fj.jtyz
福建厦门节点: xm.fj.jtyz
江西: jx.jtyz
江西上饶:sr.jx.jtyz
这就是数据库域名。
数据库域名在存在于参数⽂件中,他的参数是db_domain.
查询数据库域名
⽅法⼀:select value from v$parameter where name = 'db_domain';
⽅法⼆:show parameter domain
⽅法三:在参数⽂件中查询。
全局数据库名
全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:oradb.fj.jtyz
四、数据库服务名
什么是数据库服务名?
从oracle9i版本开始,引⼊了⼀个新的参数,即数据库服务名。参数名是SERVICE_NAME。
如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。
查询数据库服务名
⽅法⼀:select value from v$parameter where name = 'service_name';
⽅法⼆:show parameter service_name
⽅法三:在参数⽂件中查询。
数据库服务名与⽹络连接
从oracle8i开如的oracle⽹络组件,数据库与客户端的连接主机串使⽤数据库服务名。之前⽤的是ORACLE_SID,即数据库实例名
创建Oracle数据库(以Oracle10g为例)
有两种创建数据库的⽅式,⼀种是以命令⾏脚本⽅式,即⼿动⽅式创建;另⼀种是利⽤Oracle提供的数据库配置向导来创建。本篇主要介绍在Unix和Windows下以命令⾏脚本⽅式创建Oracle数据库。
⼀个完整的数据库系统,应包括⼀个物理结构、⼀个逻辑结构、⼀个内存结构和⼀个进程结构,如果要
创建⼀个新的数据库,则这些结构都必须完整的建⽴起来。
⼀、在Unix下创建数据库
1.确定数据库名、数据库实例名和服务名
关于数据库名、数据库实例名和服务名,我之前有专门⽤⼀篇来详细介绍。这⾥就不再说明了。
2.创建参数⽂件
参数⽂件很确定了数据库的总体结构。Oracle10g有两种参数⽂件,⼀个是⽂本参数⽂件,⼀种是服务器参数⽂件。在创建数据库时先创建⽂本参数⽂件,在数据库创建后,可以由⽂件参数⽂件创建服务器参数⽂件。⽂本参数⽂件的取名⽅式为a,其中,ORACLE_SID是 数据库实例名。其名称及路径为:
/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/a
其中,DB_NAME为数据库名。所以,应创建⼀个以之命名的⽬录,并将⽂本参数⽂件存放在上述⽬录中。假设新创建的数据库名为MYORACLE,SID与数据库名⼀致。则上述⽬录实际为:
/home/app/oracle/product/10.1.0/admin/MYORACLE/a
1)参数⽂件的介绍
参数⽂件决定着数据库的总体结构,⽤于设置数据库的近260个系统参数。下⾯分类别说明⼀下各参数的作⽤,关于参数的详细使⽤说明请参考Oracle官⽅参考⽂档。
a.数据库标识类参数
DB_NAME: 数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制⽂件
DB_DOMAIN: 数据库域名,⽤于区别同名数据库。数据库名与域名⼀起构成了全局数据库名
INSTANCE_NAME: 数据库实例名,可以与数据库相同
SERVICE_NAMES: 数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名
b.⽇志管理类参数
LOG_ARCHIVE_START: 是否启动⾃动归档进程ARCH
LOG_ARCHIVE_DEST: 归档⽇志⽂件存储⽬录
LOG_ARCHIVE_FORMAT: 归档⽇志⽂件的默认⽂件存储格式
LOG_ARCHIVE_DUPLEX_DEST: 归档⽇志⽂件镜像存储⽬录(Oracle8以上)
LOG_ARCHIVE_DEST_n: 归档⽇志⽂件存储⽬录(Oracle8i以上)
LOG_ARCHIVE_DEST_STATE_n: 设置参数LOG_ARCHIVE_DEST_n失效或⽣效
LOG_ARCHIVE_MAX_PROCESSES: 设置⾃动归档进程的个数
LOG_ARCHIVE_MIN_SUCCEED_DEST: 设置最少的成功归档⽇志存储⽬录的个数
LOG_CHECKPOINT_INTERVAL: 根据⽇志数量设置检验点频率
LOG_CHECKPOINT_TIMEOUT: 根据时间间隔设置检验点频率
c.内存管理参数
DB_BLOCK_SIZE: 标准数据块⼤⼩
DB_nK_CACHE_SIZE: ⾮标准数据块数据缓冲区⼤⼩
SHARED_POOL_SIZE: 共享池⼤⼩控制参数,单位为字节
DB_CACHE_SIZE: 标准数据块数据缓冲区⼤⼩
DB_BLOCK_BUFFERS: 数据缓冲区⼤⼩,9i之后已放弃使⽤
LOG_BUFFER: ⽇志缓冲区⼤⼩
SORT_AREA_SIZE: 排序区⼤⼩
LARGE_POOL_SIZE: ⼤池⼤⼩
JAVA_POOL_SIZE:Java池⼤⼩
安装oracle10gd.最⼤许可⽤户数量限制参数
LICENSE_MAX_SESSIONS:数据库可以连接的最⼤会话数
LICENSE_MAX_USERS:数据库⽀持的最⼤⽤户数
LICENSE_MAX_WARNING:数据库最⼤警告会数(会话数据达到这个值时,产⽣新会话时就会产⽣警告信息)e.系统跟踪信息管理参数
USER_DUMP_DEST:⽤户跟踪⽂件⽣成的设置
BACKGROUND_DUMP_DEST:后台进程跟踪⽂件⽣成的位置
MAX_DUMPFILE_SIZE:跟踪⽂件的最⼤尺⼨
f.系统性能优化与动态统计参数
SQL_TRACE:设置SQL跟踪
TIMED_STATICS:设置动态统计
AUDIT_TRAIL:启动数据库审计功能
g.其他系统参数
CONTROL_FILES:控制⽂件名及路径
Undo_MANAGMENT:Undo空间管理⽅式
ROLLBACK_SEGMENTS:为这个例程分配的回退段名
OPEN_CURSORS:⼀个⽤户⼀次可以打开的游标的最⼤值
PROCESSES:最⼤进程数,包括后台进程与服务器进程
IFILE:另⼀个参数⽂件的名字
DB_RECOVERY_FILE_DEST:⾃动数据库备份⽬录
DB_RECOVERY_FILE_SIZE:数据库备份⽂件⼤⼩
2)参数⽂件样式
db_name=myoracle
instance_name=myoracle
db_domain=fangys.xiya
service_names=myoracle.fangys.xiya
control_files=(/home/app/oracle/product/10.1.0/oradata/l,
/home/app/oracle/product/10.1.0/oradata/l,
/
home/app/oracle/product/10.1.0/oradata/l)
db_block_size=8192
user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udump
background_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdump
core_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdump
db_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_area
db_recovery_file_size=100G
...
3.设置操作系统参数
$ORACLE_SID=myoracle
$export ORACLE_SID
4.启动实例并创建数据库
在创建数据库之前,⾸先要以新的数据库参数启动数据库实例,因为这时数据库的控制⽂件还没有产⽣,不能MOUNT或OPEN数据库。启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。
$sqlplus "sys/pass as sysdba"
sql>startup nomount
如果参数⽂件不在规定的⽬录中,可以在启动实例时指定参数⽂件:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。