首页 > 代码库 > oracle实例名,数据库名,服务名等概念差别与联系

oracle实例名,数据库名,服务名等概念差别与联系

数据库名、实例名、数据库域名、全局数据库名、服务名
这是几个令非常多刚開始学习的人easy混淆的概念。相信非常多刚開始学习的人都与我一样被标题上这些个概念搞得一头雾水。我们如今就来把它们弄个明确。

 

一、数据库名


什么是数据库名?

数据库名就是一个数据库的标识,就像人的身份证号一样。他用參数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/pfile/ini.ora
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.ora
跟踪文件文件夹:
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并行server架构(即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:协议适配器错误”。

数据库实例名与网络连接


数据库实例名除了与操作系统交互外,还用于网络连接的oracleserver标识。当你配置oracle主机连接串的时候,就须要指定实例名。当然8i以后版本号的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。

 

三、数据库域名


什么是数据库域名?

在分布工数据库系统中,不同版本号的数据库server之间,不论执行的操作系统是unix或是windows,各server之间都能够通过数据库链路进行远程复制,数据库域名主要用于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网络组件,数据库与client的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名

 

创建Oracle数据库(以Oracle10g为例)

 

有两种创建数据库的方式,一种是以命令行脚本方式,即手动方式创建;还有一种是利用Oracle提供的数据库配置向导来创建。本篇主要介绍在Unix和Windows下以命令行脚本方式创建Oracle数据库。

一个完整的数据库系统,应包含一个物理结构、一个逻辑结构、一个内存结构和一个进程结构,假设要创建一个新的数据库,则这些结构都必须完整的建立起来。

 

一、在Unix下创建数据库


1.确定数据库名、数据库实例名和服务名
关于数据库名、数据库实例名和服务名,我之前有专门用一篇来具体介绍。这里就不再说明了。

 

2.创建參数文件
     參数文件非常确定了数据库的整体结构。Oracle10g有两种參数文件,一个是文本參数文件,一种是server參数文件。在创建数据库时先创建文本參数文件, 在数据库创建后,能够由文件參数文件创建server參数文件。文本參数文件的取名方式为initORACLE_SID.ora,当中,ORACLE_SID是 数据库实例名。其名称及路径为:
/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.ora
当中,DB_NAME为数据库名。所以,应创建一个以之命名的文件夹,并将文本參数文件存放在上述文件夹中。如果新创建的数据库名为MYORACLE,SID与数据库名一致。则上述文件夹实际为:
/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.ora


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池大小


d.最大许可用户数量限制參数
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:最大进程数,包含后台进程与server进程
IFILE:还有一个參数文件的名字
DB_RECOVERY_FILE_DEST:自己主动数据库备份文件夹
DB_RECOVERY_FILE_SIZE:数据库备份文件大小


2)參数文件样式
db_name=myoracle
instance_name=myoracle
db_domain=fangys.xiya.com
service_names=myoracle.fangys.xiya.com
control_files=(/home/app/oracle/product/10.1.0/oradata/myoracle/control01.ctl,
/home/app/oracle/product/10.1.0/oradata/myoracle/control02.ctl,
/home/app/oracle/product/10.1.0/oradata/myoracle/control03.ctl)
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
假设參数文件不在规定的文件夹中,能够在启动实例时指定參数文件:
sql>startup pfile=/export/home/user/initmyoracle.init nomount
在实例启动后就能够使用CREATE DATABASE命令创建数据。其具体语法请參考Oracle官方SQL參考文档。这里以实例来介绍:
sql>CREATE DATABASE myoracle
MAXINSTANCE 1
MAXLOGHISTORY 216
MAXLOGFILES 50
MAXLOGMEMBERS 5
DATAFILE ‘/home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf‘ SIZE 500m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
LOGFILE
GROUP 1(‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log1a.log‘,
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log1b.log‘) SIZE 10m,
GROUP 2(‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log2a.log‘,
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log2b.log‘) SIZE 10m,
GROUP 3(‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log3a.log‘,
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/log3b.log‘) SIZE 10m,
Undo TABLESPACE undotbs DATAFILE
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/undotbs01.dbf‘ size 200m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
DEFAULT TEMPORARY TALESPACE temp TEMPFILE
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf‘ size 325m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
DEFAULT TABLESPACE users DATAFILE
‘/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf‘ size 1000m
CHARACTER SET ZHS16GBK;
这里说明一下CREATE DATABASE语句的各个keyword的含义:
DATAFILE:SYSTEM表空间的数据文件定义
LOGFILE:日志文件组的定义
Undo_TABLESPACE:重做表空间的定义
DEFAULT TEMPORTY TABLESPACE:默认暂时表空间的定义
DEFAULT TABLESPACE:默认数据表空间的定义。


5.创建数据字典
在数据库创建结束后,数据库自己主动处于OPEN状态下,这时全部V$××××类数据字典都能够查询。而其他数据字典,如DBA_DATA_FILES、DBA_TABLESPACES等都不存在,必须通过下列骤为系统创建数据字典。
1)载入经常使用的数据字典包
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/catalog
2)载入PL/SQL程序包
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catproc
3)载入数据复制支持软件
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep
4)载入Java程序包
sql>@/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvm
5)载入系统环境文件
sql>connect system/pass
sql>@/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld

 

二、在Windows下创建数据库
Oracle实例在Windows下表现为操作系统服务。在windows下,使用命令行方式创建数据的方法有所不同,区别在于在Windows下,须要先创建数据库服务和实例。

 

1.确定数据库名、数据库实例名和服务名并创建文件夹(DBCA创建的脚本不包括建立文件夹命令,须自己创建)
建立文件夹命令(以下以 db_name=eygle为例):

mkdir D:/oracle/ora90/cfgtoollogs/dbca/eygle
mkdir D:/oracle/ora90/database
mkdir d:/oracle/admin/eygle/adump
mkdir d:/oracle/admin/eygle/bdump
mkdir d:/oracle/admin/eygle/cdump
mkdir d:/oracle/admin/eygle/dpdump
mkdir d:/oracle/admin/eygle/pfile
mkdir d:/oracle/admin/eygle/udump
mkdir d:/oracle/flash_recovery_area
mkdir d:/oracle/oradata
mkdir d:/oracle/oradata/eygle

 

2.创建參数文件
在Windows下的參数文件名及路径例如以下:
d:/oracle/product/10.1.0/admin/DB_NAME/pfile/init.ora(oracle10g)
d:/orant/database/iniORACLE_SID.ora(oracle7,oracle8)
參数据文件内容与前述一致。这里不再说明。

 

3.选择数据库实例
环境变量设置ORACLE_SID
c:/>set ORACLE_SID=数据库实例名

 

4.创建数据库实例
在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,能够在操作系统符号下直接执行。直接输入oradim显示此命令的帮助。
c:/>Oradim
以下对Oradim命令的參数进行一个说明
-------------------------------
-NEW 表示新建一个实例
-EDIT 表示改动一个实例
-DELETE 表示删除一个实例
-SID sid     指定要启动的实例名称
-SRVC service 指定要启动的服务名称
-INTPWD password 以Internal方式连接数据库时的口令字
-MAXUSERS count 该实例能够连接的最大用户数
-USRPWD password 指定内部用户的口令,如是作为Windows管理登录,不用此參数
-PFILE pfile     该实例所使用的參数文件名称及路径
-STARTTYPE srvc|inst|srvc,inst 启动选项(srvc:仅仅启动服务,inst:启动实例,服务必须先启动,srvc,inst:服务和实例同一时候启动)
-SHUTTYPE srvc|linst|srvc,inst 关闭选项(srvc:仅仅关闭服务,实例必须已关闭,inst:仅仅关闭实例,srvc,inst:服务和实例同一时候关闭)
-STARTMODE a|m 创建实例所使用的模式(a:自己主动,即windows启动时自己主动启动 m:手动)
-SHUTMODE a|i|m 关闭实例时所使用的模式(a:abort异常方式,i:immediate马上方式,n:normal正常方式)
----------------------------
例:创建一个数据库实例
c:/>oradim -NEW -SID myoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"

c:/>oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"
例:改动一个数据实例
c:/>oradim -EDIT -SID myoracle -STARTMODE a

c:/>oradim -EDIT -SRVC OracleServicemyoracle -STARTMODE a
例:删除一个实例
c:/>oradim -DELETE -SID myoracle

c:/>oradim -DELETE -SRVC Oracleservicemyoracle
例:启动服务与实例
c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvc,inst
仅仅启动服务
c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvc
启动实例:
c:/>oradim -STARTUP -SID myoracle -STARTTYPE inst
例:关闭服务与实例
c:/>oradim -SHUTDOWN -SID myoracle  
c:/>oradim -SHUTDOWN -SID myoracle -SHUTTYPE srvc,inst

 

5.启动实例并创建数据库
c:/>oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:/fangys/initmyoracle.ora
c:/>set ORACLE_SID=myoracle
c:/>sqlplus sys/syspass as sysdba
sql>startup -pfile=d:/fangys/initmyoracle.ora nomount
sql>CREATE DATABASE myoracle
logfile group...
...

 

6.创建数据字典
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catalog.sql;
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catproc.sql;
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catrep.sql;
sql>@d:/oracle/product/10.1.0/db_1/javavm/install/initjvm.sql;
sql>@d:/oracle/product/10.1.0/db_1/sqlplus/admin/ppbld.sql;

 

一、启动数据
$sqlplus "sys/pass as sysdba"
sql>startup

 

二、启动监听器
数据库启动后,假设未启动监听进程,则client无法与数据库连接。监听进程的启动方法为:
$lsnrctl start
在widnows中,能够从服务列表中启动监听器。
监听里程配置文件为listener.ora,位于文件夹/home/app/oracle/product/10.1.0/db1/network/admin/。
此配置文件分为两部分,一部分为监听程序本身的配置,包含协议,地址,port号等;还有一部分为监听程序所连接的数据库的实例信息,包含:实例名,全局数据库名,oracle主文件夹等。监听器能够利用oracle net config 向导来配置。
要显示监听器的执行状态:$lsnrctl status;
要停止监听器:$lsnrctl stop。

 

三、数据库的启动过程
分为三个阶段:


1. 启动实例,包含下面操作:
1) 读取參数文件
2) 分配SGA
3) 启动后台进程


2.装载数据库
装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。

3.打开数据库
此步骤使用数据库能够进行正常的操作的处理。主要是打开控制文件,数据库文件和日志文件。

 

四、数据库启动參数
1.NOMOUNT:仅仅启动实例,不装载数据库
sql>startup nomount
2.MOUNT:启动实例,并装载数据,但不打开数据库
sql>startup mount
3.READ ONLY:将数据库置为仅仅读
sql>startup mount
sql>alter database open read only
4.READ WRITE:以可读写方式打开数据,这是默认方式
sql>startup mount
sql>alter database open read write
5.OPEN:打开数据库,这是默认方式
sql>startup mount
sql>alter database open;
6.RESTRICT:以受限方式打开,仅仅有具有RESTRICTED SESSION权限的用户才干够连接数据库
sql>startup restrict
7.PFILE:启时指定參数文件
sql>startup pfile=/u02/user/mypfile.ora
8.FORCE:以强制方式启动数据库
sql>startup pfile=/u02/user/mypfile.ora open restrict force

 

五、数据库的关闭
与启动过程相相应,关闭包含三个过程


1).关闭数据库
2).卸载数据库
3).关闭数据库实例

 

1.NORMAL关闭方式
NORMAL关闭方式是正常关闭方式,是默认关闭方式。在这样的关机方式下,数据库server必须等待全部client从Oracle中正常退出时,才干够关闭数据库。
SQL>SHUTDOWN NORMAL


2.IMMEDIATE关闭方式
使用这样的方式关闭数据库时,系统将连接到数据库的所实用户尚未提交的事务所有回退,中断连接,然后关闭数据库。
SQL>SHUTDOWN IMMEDIATE


3.ABORT关闭方式
ABORT关闭方式为异常方式,使用这样的方式关闭数据库时,系统马上将数据库实例关闭,对事务膛数据完整性不作检查。是最快的关机方式。
sql>shutdown abort;


4.TRANSACTIONAL关闭方式
在这样的关机方式中,数据库必须等待全部的客户执行的事务结束,提交或回退。
sql>shutdown transactional

 

Oracle数据库的连接结构有三种:
1) 组合用户与server结构:在这样的连接方式中,client与server同处一台机器中,对于每个用户,其库应用程序与server程序组合成单个server进程。
2) 专用server(Dedicated Server)结构:在这样的方式中,对于每个用户,其数据库应用是由用户进程所执行,并有一个专用server进程为之服务,执行Oracleserver代码。
3) 多线程server(Multithreaded Server)体系结构:在这样的方式中,一个或多个客户应用程序共享一组server进程,与专用server不同的是,客户和server进程不是一对一的关系,而是由调度进程对多个server进程进行调度,以服务来自客户应用的连接请求。

 

专用server


专用server的工作过程:
1) client通过oracle net向监听器发连接请求
2) 监听器收到请求并将此请求导向server,server向用户返回一个连接成功信息,并为此用户创建一个专用server进程
3) 客户直接与该专用server进程进行交互,处理SQL,而且server在该会话的PGA中建立一个专用SQL区。
假设client要求建立专用server连接方式,能够改动客户羰的网络配置文件tnsnames.ora或改动连接描写叙述串。添加keyword“Server=DEDICATED”,如:
prod=
(DESCRIPTION=
(ADDRESSLIST=
(ADDRESS=
(PROTOCOL=TCP)(HOST=192.168.0.3)(PORT=1521)
(SERVER=DEDICATED)
)
)
(CONNECT_DATA=http://www.mamicode.com/(SID=PROD)
)
)
还必须改动SQLNET.ORA文件,添加“USE_DEDICATED_SERVER=TRUE”

 

多线程server体系结构

专用server结构中,一个server进程仅仅为一个客户服务。这种话,假设有一千个客户,就须要有一千个对应的server进程,就会耗费大量的系统资源。为了支 持对于可伸缩性的需求,在oracle7中引入了多线程server(MTS,也称为共享server)。以下说明共享server建立连接的过程,以级与建立专用server连 接过程的不同:
1) 客户通过网络与监听器联系
2) 监听器检測到请求,基于Oracle net结构来确定是否与多线程server连接。监听器将客户请求导向对应的调度程序。
3) 监听器通过使客户与调度程序了解对方的网络地址,从面完毕了两方的介绍。
4) 一旦客户与调度程序知道怎样找到对方,它们就直接通信,不要须要监听器。客户直接将操作请求发送给高度程序。
5) 调度程序将客户请求放在SGA的请求队列中。
6) 下一个可用的共享server进程从请求队列中读取请求,进行对应的工作。
7) 共享server进程将结果存放在提交对应请求的调度程序的响应队列中。
8) 调度程序从响应队列中读取数据并将结果送组客户。


  

有几个概念在这里作个补充说明:
1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与server的中介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向对应的实例。
2) 调度程序(dispatcher):在MTS体系结构中,监听器与调度程序联系,调度程序负责调度MTS中的各个共享server进程。


多线程server的设置參数有:
MTS_SERVICE:多线程server名称,一般为数据库名
MTS_DISPATCHERS:初始调度器个数
MTS_MAX_DISPATCHERS:调度器最大个数
MTS_SERVERS:共享server个数
MTS_MAX_SERVERS:最大共享server个数
多线程server的设置是通过对以上各个參数的设置完毕的。格式例如以下:
MTS_SERVICE=RS
MTS_SERVERS=10
MTS_MAX_SERVERS=100
MTS_DISPATCHERS="(PROTOCOL=TCP)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPX)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPC)(POOL=YES)(MULT=YES)"
MTS_MAX_DISPATCHERS=100


有关多线程server的数据字典例如以下:
V$MTS
V$DISPATCHER
V$SHARED_SERVER
V$CIRCULT
各字典的具体说明请參考Oracle文档。

 

Oracle实例的进程结构

这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。
Oracle实例由内存区域和后台进程组成。
Oracle实例分为单进程实例(一个进程运行全部的Oracle代码,仅仅同意单个用户存取)和多进程实例(由多个进程运行Oracle代码的不同部分,对于每个连接的用户都有一个进程,同意多个用户同一时候使用)。
在多进程结构中,除server进程(请注意,此“server进程”不是指全部的实例中的进程,见以下的说明)外,还有其它后台进程,包含:Dnnn, DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中全部进程的数量之和不能超过參数 PROCESS设定的值:
sql>show parameter process
当Oracleclient应用程序与Oracle实例连接的时候,Oracle会产生一个server进程来为这些客户服务,此进程在widnows下表现为线程。 此进程的主要作用有:对于用户发出的SQL语句进行语法分析,编译,运行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到 SGA的共享数据缓冲区中,将SQL语句的运行结果返回组应用程序。以下的语句用来查询数据库中的用户会话信息。
sql>select substr(s.sid,1,3) sid,substr(s.serial#,1,5) ser,spid,substr(schemaname,1,10) schema,substr(type,1,3) typ,substr(decode((consistent_gets+block_gets),0,‘None‘,(100*(consistent_gets+block_gets-physical_reads)/consistent_gets+block_gets))),1,4) "%hit",value cpu,substr(block_changes,1,5) bchng from v$process p,v$sesstat t,v$sess_io i,v$session s where i.sid=s.sid and p.addr=paddr(+) and s.sid=t.sid and t.statistic#=12;
结果中:
sid 表示会话ID号,
ser 表示会话serial#号,serial#与sid组合以唯一表示一个会话,
spid 表示操作系统进程号,
schema 表示数据库username,
typ 表示进程类型,use为用户进程,bac为后台进程
%hit 表示数据缓冲区命中率,
cpu 表示使用cpu的时间,
bchng 表示改动了的数据块的个数。

 

以下介绍各个后台进程


1. DBWR进程
DBWR(Database Writer)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。
当数据缓冲区中的一个数据被改动后,被标记为“脏”,DBWR进程负责将“脏”数据写入磁盘。
DBWR採用LRU算法来替换数据缓冲区中的数据。
DBWR的作用包含:
1) 管理数据缓冲区,以便server进程总能找到空暇缓冲区
2) 将全部改动后的缓冲区中的数据写入数据库文件
3) 使用LRU算法将近期使用过的块保留在内存中
4) 通过延迟写来优化磁盘i/o.
在下列情况下DBWR要将脏数据写入磁盘数据文件:
1) 当一个server进程将缓冲数据块移“脏表”,面该脏表达到一定程度进。(该临界长度由參数DB_BLOCK_WRITE_BATCH决定)
2) 当一个server进程在LRU表中查找DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空暇的缓冲区
3) 出现超时
4) 检查点发生时
在一个Oracle实例中,同意启动多个DBWR进程,DBWR进程个数由參数DB_WRITE_PROCESSES指定,上限为20,进程名依次自己主动命名为:DBW0,DBW1,DBW2...DBW19。
sql>show parameter processes

 

2. LGWR进程
LGWR(Log Writer)进程将日志数据从日志缓冲区中写入磁盘日志文件里。
关于LGWR进程的工作时机能够看我写的第一篇《一次事务过程》。
LGWR的写盘条件是:
1) 发生提交,即commit;
2) 日志缓冲区达到总数的1/3时;
3) 超时;
4) DBWR进程须要为检验点清除缓冲区时。
每个Oracle实例仅仅有一个LGWR进程。
LGWR将日志信息同步的写入到日志文件组的多个日志成员中,假设组中的一个成员文件被删除或不可使用,LGWR将日志信息继续写到该组的其它文件里,不影响数据库的执行。

 

3. SMON进程
SMON(System Monitor),系统监控进程,在实例启动时运行实例恢复,并负责清理不再使用的暂时段。

 

4. PMON进程
PMON(Process Monitor),进程监控里程,在server进程出现问题时运行进程恢复,负责清理内存内存和释放该进程所使用的资源。

 

5. ARCH进程
ARCH(Archive Process,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质失败时的恢复。
日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组,日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。
在 一个数据库实例中,归档进程最多能够启动10个,进程名依次自己主动命名为ARC0,ARC1,ARC2...ARC9,设置方法是:在參数文件里添加 參数LOG_ARCHIVE_MAX_PROCESSES。关于怎样启用数据库的自己主动归档,在前面的《物理结构》一篇中已有说明,这里说明一个几个相关的 參数:
1) LOG_ARCHIVE_DEST:用于设置归档日志的文件存储文件夹
2) LOG_ARCHIVE_DUBLEX_DEST:用于设置归档日志文件的镜像存储文件夹,此參数在oracle 8及以上的版本号中支持
3) LOG_ARCHIVE_DEST_n:用于设置很多其它的镜像文件夹,当中,1<=n<=10,该參数有下面三个选项:
(1)MANDATORY:表示必须完毕此文件夹的归档,才干够切换。
(2)REOPEN:归档文件夹或介质失败后,需等多长时间能又一次写入日志,默认时间为300秒。
(3)OPTIONAL:无论是否归档完毕都进行切换,这是默认方式
举比例如以下:
LOG_ARCHIVE_DEST_1=‘LOCATION=/u01/oracle/archive/
MANDATORY
REOPEN=500‘
LOG_ARCHIVE_DEST_2=‘LOCATION=/u02/oracle/archive/
OPTIONAL‘
LOG_ARCHIVE_DEST_n仅仅适用于oracle 8i及以上的版本号。
4) LOG_ARCHIVE_DEST_STATE_n:用于对归档日志文件夹进行失效或生效,该參数与LOG_ARCHIVE_DEST_n一一相相应。如:
LOG_ARCHIVE_DEST_STATE_1=DEFER
LOG_ARCHIVE_DEST_STATE_2=ENABLE
此參数能够在线设置:
sql> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1=DEFER;
此參数仅仅适用于oracle 10g及以上版本号。

 

6. CKPT进程
CKPT(CheckPoint,检查点)进程出现时,系统对所有数据库文件及控制文件的文件头的同步号进行改动,以保证数据库的同步。
下面两个參数是对CKPT有影响的:
LOG_CHECKPOINT_TIMEOUT:决定产生一个检验点的时间间隔,单位为秋,默觉得1800;
LOG_CHECKPOINT_INTERVAL:运行一个检验点须要填充的日志文件块的数目,默觉得0,表示不起作用。
系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步根据,同一时候存储在这三个中,在系统改变时,检验点号也会同一时候改变。
引起CKPT产生的主要时机有:
1)日志切换时
2)达到LOG_CHECKPOINT_TIMEOUT指定的间隔时间
3)达到LOG_CHECKPOINT_INTERVAL指定的日志块数
4)数据库关闭
5)DBA强制产生
6)表空间OFFLINE时

 

7. RECO进程
RECO(Recover,恢复)进程用于分布式数据库系统,RECO进程自己主动地解决在分布式数据库中的事务故障。

 

8. LCKn进程
LCKn(锁进程)用于Oracle并行server环境下,用于多个实例间的封锁,该进程最多能够启动10个。

 

9. Dnnn进程
Dnnn(Despatcher,调度)进程。用于多线程server体系结构中。

 

10. SNP进程
SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自己主动刷新,并同一时候通达DBMS_JOB程序包自己主动执行预定的存储过程,SQL,PL/sql程序等。有两个參数用来控制作业进程的计划:
1) JOB_QUEUE_PROCESS:用于设置作业进程个数
2) JOB_QUEUE_INTERVAL:用于设置作业进程被周期性唤醒的时间间隔

 

后台进程跟踪信息
全部改动数据库结构的命令会自己主动被后台进程跟踪记录,跟踪信息由oracle后台进程自己主动存储,跟踪文件的名称为alter_SID。此文件的存储文件夹由參数BACKGROUND)DUMP_DEST指定。
能够用工具命令TKPROF来格式化跟踪文件,如:
$tkprof oralogfile1.log
除了跟踪后台进程外,还能够启用參数SQL_TRACE对用户的语句进行跟踪。改动參数文件:
TIMED_STATISTICS=TRUE
USER_DUMP_DEST=文件夹名
MAX_DUMP_FILE_SIZE=5M
SQL_TRACE=TRUE
或者:
SQL>ALTER SESSION SET SQL_TRACE=TRUE对当前会话进行SQL跟踪。

 

锁等待问题与KILL SESSION
为了保证数据的一致性,系统提供锁机制。有关锁的概念能够參数《数据库系统概论》一书。要了解当前在等待锁资源的用户:
sql>select a.username,a.sid,a,serial#,b.id1 from v$session,v$lock where a.lockwait=b.kaddr;
要了解锁住其他用户的用户进程:
SQL>SELECT A.USERNAME,A.SID,A,SERIAL#,B.ID1 FROM V$SESSION A,V$LOCK B WHERE B.ID1 IN (SELECT DISTINCT E.ID1 FROM V$SESSION D,V$LOCK E WHERE D.LOCKWAIT=E.KADDR) AND A.SID=B.SID AND B.REQUEST=0;