oracle实例名,服务名等概念区别与联系

来源:互联网 发布:mysql日期和时间函数 编辑:程序博客网 时间:2024/05/11 00:39

oracle实例名,服务名等概念区别与联系

 

一、数据库名ITPUB个人空间v{7x6lo/
什么是数据库名?
ITPUB个人空间*s*R5LVBXZ2w$I
数据库名就是一个数据库的标识,就像人的身份证号一样。他用参数DB_NAME表示,如果一台机器上装了多全数据库,那么每一个数据库都有一个数据库名。在数据库安装或创建完成之后,参数DB_NAME被写入参数文件之中。格式如下:ITPUB个人空间H s$M*r6@G-]-Q
DB_NAME=myorcl
9v[ U!iXMov+D+q0...ITPUB个人空间pk%]7Tc#e6dZ
在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。因为,数据库名还被写入控制文件中,控制文件是以 二进制型式存储的,用户无法修改控制文件的内容。假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。但是在Oracle启动时,由于参数文 件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。

数据库名的作用ITPUB个人空间K"nxp$EO9Sc
数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、备份与恢复数据库时都需要使用到的。ITPUB个人空间sm/N$xW_3a'vk
有很多Oracle安装文件目录是与数据库名相关的,如:ITPUB个人空间$Q(mm*s a%V8af-q,h
winnt: d:/oracle/product/10.1.0/oradata/DB_NAME/...ITPUB个人空间$Z V Q&S^
Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/...
*tYN@CH0pfile:ITPUB个人空间Y:Ll5zG4t`A
winnt: d:/oracle/product/10.1.0/admin/DB_NAME/pfile/ini.oraITPUB个人空间G_h7Q)}Ii6~3j
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.ora
sx(V'ea1p f#Nv[0跟踪文件目录:ITPUB个人空间|~!Py+P-YBaY:|
winnt: /home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...
~}1M,q#WF:KW;g0另外,在创建数据时,careate database命令中的数据库名也要与参数文件中DB_NAME参数的值一致,否则将产生错误。
4s8]?!V*Ny0同样,修改数据库结构的语句alter database, 当然也要指出要修改的数据库的名称。ITPUB个人空间Y9S(n}l;S
如果控制文件损坏或丢失,数据库将不能加载,这时要重新创建控制文件,方法是以nomount方式启动实例,然后以create controlfile命令创建控制文件,当然这个命令中也是指指DB_NAME。ITPUB个人空间#{O8d5c `)xO
还有在备份或恢复数据库时,都需要用到数据库名。ITPUB个人空间.m f)V JT"JS0H
总之,数据库名很重要,要准确理解它的作用。

查询当前数据名
M1?6}.V i2f)X0方法一:select name from v$database;ITPUB个人空间7{M(f A&o9B
方法二:show parameter dbITPUB个人空间.Jd0mL*xY%|e)`
方法三:查看参数文件。

修改数据库名
4^t4sk[t0前面建议:应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是一件比较复杂的事情。那么现在就来说明一下,如何在已创建数据之后,修改数据库名。步骤如下:
)T4zTKg8O'oR01.关闭数据库。
&ui)P.J+D-~ j|Me N02.修改数据库参数文件中的DB_NAME参数的值为新的数据库名。ITPUB个人空间C2fz]o#?Ob:^
3.以NOMOUNT方式启动实例,修建控制文件(有关创建控制文件的命令语法,请参考oracle文档)

二、数据库实例名ITPUB个人空间 q#H XP s I:Q pu
什么是数据库实例名?
%rx_#aL1U7/0
数据库实例名是用于和操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。实例名也被写入参数文件中,该参数为instance_name,在winnt平台中,实例名同时也被写入注册表。ITPUB个人空间|cG,rKiI${
数据库名和实例名可以相同也可以不同。
G+N(}/~1` uW$|d/m0在一般情况下,数据库名和实例名是一对一的关系,但如果在oracle并行服务器架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。这一点在第一篇中已有图例说明。

查询当前数据库实例名
}+V7K;|!Br0方法一:select instance_name from v$instance;ITPUB个人空间LJ0`-F`.mwH
方法二:show parameter instanceITPUB个人空间R~$T"_8@?&R w
方法三:在参数文件中查询。

数据库实例名与ORACLE_SID
[;j X#NY} e3]0虽然两者都表是oracle实例,但两者是有区别的。instance_name是oracle数据库参数。而ORACLE_SID是操作系统的环境变 量。 ORACLD_SID用于与操作系统交互,也就是说,从操作系统的角度访问实例名,必须通过ORACLE_SID。在winnt不台, ORACLE_SID还需存在于注册表中。
:X$A+BLx?*C0且ORACLE_SID必须与instance_name的值一致,否则,你将会收到一个错误,在unix平台,是“ORACLE not available”,在winnt平台,是“TNS:协议适配器错误”。

数据库实例名与网络连接ITPUB个人空间!ur*^t%m;^
数据库实例名除了与操作系统交互外,还用于网络连接的oracle服务器标识。当你配置oracle主机连接串的时候,就需要指定实例名。当然8i以后版本的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。

三、数据库域名
_.e$SL%l Iy0什么是数据库域名?

@wQ[3Gj3m4G,p&yu0在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于oracle分布式环境中的复制。举例说明如:ITPUB个人空间SJO]a ||x
全国交通运政系统的分布式数据库,其中:
Q?3t U R0福建节点: fj.jtyzITPUB个人空间:f$Irg Y s:f {1S
福建厦门节点: xm.fj.jtyz
k,H _ s!~l B/sck0江西: jx.jtyz
Wg(Vq/b0江西上饶:sr.jx.jtyz
*V2^$w5OBA0这就是数据库域名。ITPUB个人空间;i iP&O5E*f5R
数据库域名在存在于参数文件中,他的参数是db_domain.

查询数据库域名
%Cwp*Q9CM4p0方法一:select value from v$parameter where name = 'db_domain';ITPUB个人空间 b'A:gTL
方法二:show parameter domain
(X5]'^:Pv sI0方法三:在参数文件中查询。

全局数据库名
YC(V9J w Jd)v0全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:oradb.fj.jtyz

四、数据库服务名ITPUB个人空间_,PJuFI-Ai1b0p
什么是数据库服务名?
-X@v_2cl0
从oracle9i版本开始,引入了一个新的参数,即数据库服务名。参数名是SERVICE_NAME。ITPUB个人空间"D? rv[*J
如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。

查询数据库服务名
El3h/LF2b0方法一:select value from v$parameter where name = 'service_name';ITPUB个人空间6A~b{`Y@
方法二:show parameter service_nameITPUB个人空间1mch(Q|K+g
方法三:在参数文件中查询。

数据库服务名与网络连接
#B$@qt w1_zHH{ z0
从oracle8i开如的oracle网络组件,数据库与客户端的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名
4j-L-h[/m CP0
q0_;xChH:dY3a0

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

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

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

一、在Unix下创建数据库
W6a y+G V"u Q01.确定数据库名、数据库实例名和服务名ITPUB个人空间"Q*|E#dGl&m^J
关于数据库名、数据库实例名和服务名,我之前有专门用一篇来详细介绍。这里就不再说明了。

2.创建参数文件ITPUB个人空间GG,J3jW7Vfn"c_
     参数文件很确定了数据库的总体结构。Oracle10g有两种参数文件,一个是文本参数文件,一种是服务器参数文件。在创建数据库时先创建文本参数文件, 在数据库创建后,可以由文件参数文件创建服务器参数文件。文本参数文件的取名方式为initORACLE_SID.ora,其中,ORACLE_SID是 数据库实例名。其名称及路径为:
)Z%I a oEC1C*Dt&j@~0/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.oraITPUB个人空间8y(n {%|*y8MtY T
其中,DB_NAME为数据库名。所以,应创建一个以之命名的目录,并将文本参数文件存放在上述目录中。假设新创建的数据库名为MYORACLE,SID与数据库名一致。则上述目录实际为:ITPUB个人空间f3/C1xys'{t`&L.R^
/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.oraITPUB个人空间%i&RJ1M+M'pY
1)参数文件的介绍
$jmg A"b J0参数文件决定着数据库的总体结构,用于设置数据库的近260个系统参数。下面分类别说明一下各参数的作用,关于参数的详细使用说明请参考Oracle官方参考文档。
M7WLJ~y5h0a.数据库标识类参数
j%v3V*X@d8n0
DB_NAME: 数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制文件
2`Ez0V&j"U0DB_DOMAIN: 数据库域名,用于区别同名数据库。数据库名与域名一起构成了全局数据库名
UU_a3w1rqtkD0INSTANCE_NAME: 数据库实例名,可以与数据库相同
u uOs:}0SERVICE_NAMES: 数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名
VvF.bv*I0h0b.日志管理类参数ITPUB个人空间kl@%eiV;yXJR,_
LOG_ARCHIVE_START: 是否启动自动归档进程ARCHITPUB个人空间`@#p/ZeV(}IC
LOG_ARCHIVE_DEST: 归档日志文件存储目录
?pEN,|!IW h0LOG_ARCHIVE_FORMAT: 归档日志文件的默认文件存储格式
!_J*Xo@6Y0LOG_ARCHIVE_DUPLEX_DEST: 归档日志文件镜像存储目录(Oracle8以上)
t,P kMt] `(g l0LOG_ARCHIVE_DEST_n: 归档日志文件存储目录(Oracle8i以上)
%H7cg"`.a%u+cAp0LOG_ARCHIVE_DEST_STATE_n: 设置参数LOG_ARCHIVE_DEST_n失效或生效ITPUB个人空间&lUH8H]w8LD
LOG_ARCHIVE_MAX_PROCESSES: 设置自动归档进程的个数ITPUB个人空间:j c"k,d*PfP!vS
LOG_ARCHIVE_MIN_SUCCEED_DEST: 设置最少的成功归档日志存储目录的个数ITPUB个人空间bS/a%T5vJG
LOG_CHECKPOINT_INTERVAL: 根据日志数量设置检验点频率ITPUB个人空间x7R,l l9g M
LOG_CHECKPOINT_TIMEOUT: 根据时间间隔设置检验点频率
5Fd1n/R{0c.内存管理参数ITPUB个人空间b)WI'w/b#E&W
DB_BLOCK_SIZE: 标准数据块大小
U"j"Be&Rh%EF.G0DB_nK_CACHE_SIZE: 非标准数据块数据缓冲区大小
#q,d-| F j"Y~6np;M0SHARED_POOL_SIZE: 共享池大小控制参数,单位为字节ITPUB个人空间H Of d,Y0_3y8F
DB_CACHE_SIZE: 标准数据块数据缓冲区大小ITPUB个人空间#jn'/4l4c%VkN1/U{
DB_BLOCK_BUFFERS: 数据缓冲区大小,9i之后已放弃使用ITPUB个人空间6ne/ro N {
LOG_BUFFER: 日志缓冲区大小ITPUB个人空间lw0C#w+C+c"a
SORT_AREA_SIZE: 排序区大小ITPUB个人空间2O9Lw7v'i#n4yv0N
LARGE_POOL_SIZE: 大池大小
9cfVzN J4q2z0JAVA_POOL_SIZE:Java池大小
d*dti9Wp:]V(`0d.最大许可用户数量限制参数ITPUB个人空间[WaPbFfv[Y
LICENSE_MAX_SESSIONS:数据库可以连接的最大会话数
'HU#Ji.h/m_ E0LICENSE_MAX_USERS:数据库支持的最大用户数
{n%T0},K)ik0LICENSE_MAX_WARNING:数据库最大警告会数(会话数据达到这个值时,产生新会话时就会产生警告信息)
F|/Z%Wz9W:JB b0e.系统跟踪信息管理参数ITPUB个人空间6Z2v~2Rw$mj9g
USER_DUMP_DEST:用户跟踪文件生成的设置
9nN3x rc.|0BACKGROUND_DUMP_DEST:后台进程跟踪文件生成的位置ITPUB个人空间7~0l6|MJD
MAX_DUMPFILE_SIZE:跟踪文件的最大尺寸ITPUB个人空间mI@-p:Y p
f.系统性能优化与动态统计参数
?;BK-Wpg6cM0
SQL_TRACE:设置SQL跟踪
)K N9jw9Oa0YF0TIMED_STATICS:设置动态统计ITPUB个人空间 V E Xb u2Y&N$]
AUDIT_TRAIL:启动数据库审计功能ITPUB个人空间%b&Q| rvb4Bt
g.其他系统参数ITPUB个人空间4s"i9Cal
CONTROL_FILES:控制文件名及路径
A ^%Wa+m @/SK F0Undo_MANAGMENT:Undo空间管理方式ITPUB个人空间%R%a C ]m%B)o:L-r
ROLLBACK_SEGMENTS:为这个例程分配的回退段名
u&aalLTA1M0OPEN_CURSORS:一个用户一次可以打开的游标的最大值ITPUB个人空间1qv'y8B/lIhWA
PROCESSES:最大进程数,包括后台进程与服务器进程ITPUB个人空间c;bD E8}!AvA
IFILE:另一个参数文件的名字ITPUB个人空间B[m3q5/-Ng
DB_RECOVERY_FILE_DEST:自动数据库备份目录
Yvsg${;e0DB_RECOVERY_FILE_SIZE:数据库备份文件大小
/TrL,p,ML02)参数文件样式ITPUB个人空间'iGp&o e/X8A
db_name=myoracleITPUB个人空间Sg&G;poh L6r
instance_name=myoracleITPUB个人空间B[C"U0Ol4b3k
db_domain=fangys.xiya.com
}o)w'O8k o%K-o^q ]0service_names=myoracle.fangys.xiya.com
,p#P:ZZ)wx@Q U0control_files=(/home/app/oracle/product/10.1.0/oradata/myoracle/control01.ctl,
J6B!N6dB0L*?!|0                  /home/app/oracle/product/10.1.0/oradata/myoracle/control02.ctl,ITPUB个人空间o/veI5D{}o*T~
                  /home/app/oracle/product/10.1.0/oradata/myoracle/control03.ctl)ITPUB个人空间1sB{;ofhD(}+W
db_block_size=8192ITPUB个人空间p f#a,sHN$Ug
user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udump
a rQh.Q|#v wN0background_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdumpITPUB个人空间fS;Ts0X{f
core_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdumpITPUB个人空间&zc lb!j3uHG
db_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_area
1{@6@q.?T:vYq0db_recovery_file_size=100GITPUB个人空间"`K N&_8/)i d
...

ITPUB个人空间 S#zoL:Y7a#F
3.设置操作系统参数
)dFBG.R0$ORACLE_SID=myoracle
&ec.~ia0$export ORACLE_SID

4.启动实例并创建数据库
*Q-u gD6D!~$T0
在创建数据库之前,首先要以新的数据库参数启动数据库实例,因为这时数据库的控制文件还没有产生,不能MOUNT或OPEN数据库。启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。ITPUB个人空间 B.S9?Ek"Y
$sqlplus "sys/pass as sysdba"

sql>startup nomount
mm$B(K/o!n0如果参数文件不在规定的目录中,可以在启动实例时指定参数文件:ITPUB个人空间T$v)wCQ6e
sql>startup pfile=/export/home/user/initmyoracle.init nomount
Fy P:F;q/(n~i[ P0在实例启动后就可以使用CREATE DATABASE命令创建数据。其详细语法请参考Oracle官方SQL参考文档。这里以实例来介绍:
UMDbh2Ve!T0sql>CREATE DATABASE myoracleITPUB个人空间v5^#S(E1dP2ivD
       MAXINSTANCE 1ITPUB个人空间1m7I iU/K%w
       MAXLOGHISTORY 216
w!vrY(r[:Oa,l0       MAXLOGFILES 50
:c"E7l X'u$U4CU"a| K0       MAXLOGMEMBERS 5ITPUB个人空间H%}I;|,X:Y(?
DATAFILE '/home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf' SIZE 500mITPUB个人空间N4JB!K g@xPe1@o
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
_ x u%mgT%a*k0LOGFILE
[T|/d.mrv0       GROUP 1('/home1/app/oracle/product/10.1.0/oradata/myoracle/log1a.log',
~/b#mT)X$_;v1r0               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log1b.log') SIZE 10m,
^ JG-s oiZ)O~a0L0       GROUP 2('/home1/app/oracle/product/10.1.0/oradata/myoracle/log2a.log',
5z^:H@(Wcktb0               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log2b.log') SIZE 10m,ITPUB个人空间M f#N8v#/ aG}g
       GROUP 3('/home1/app/oracle/product/10.1.0/oradata/myoracle/log3a.log',
d2O p6g'Ig!X6S*H0               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log3b.log') SIZE 10m,
~dmza ZR0Undo TABLESPACE undotbs DATAFILEITPUB个人空间``]-s4KM3?K
'/home1/app/oracle/product/10.1.0/oradata/myoracle/undotbs01.dbf' size 200mITPUB个人空间`6}.Af hW5S
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDITPUB个人空间5|0}/S} HI!^8^
DEFAULT TEMPORARY TALESPACE temp TEMPFILE
:F*kJ oBRIj0'/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf' size 325mITPUB个人空间O^%qvTvQW{$}5?p
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDITPUB个人空间6DPhBC&yl{w1Y%E
DEFAULT TABLESPACE users DATAFILE
*iN]*BvhL0'/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf' size 1000m
5so-{n H%p'[/g0CHARACTER SET ZHS16GBK;ITPUB个人空间5o;Td;wUn~;D
这里说明一下CREATE DATABASE语句的各个关键字的含义:
h+D;UU,~/7bEU0DATAFILE:SYSTEM表空间的数据文件定义ITPUB个人空间k"vg3YA9UW%a
LOGFILE:日志文件组的定义
4E k[3cf E%E}"[&X0Undo_TABLESPACE:重做表空间的定义
%g,uQ4Nj6K QY0DEFAULT TEMPORTY TABLESPACE:默认临时表空间的定义ITPUB个人空间zW$i#k {
DEFAULT TABLESPACE:默认数据表空间的定义。


xE-f] HB3E05.创建数据字典
"W-P-c(p ew!A n0在数据库创建结束后,数据库自动处于OPEN状态下,这时所有V$××××类数据字典都可以查询。而其它数据字典,如DBA_DATA_FILES、DBA_TABLESPACES等都不存在,必须通过下列骤为系统创建数据字典。ITPUB个人空间N,FK%k'`
1)加载常用的数据字典包
e+[9@5@/,u^{ F0sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/catalogITPUB个人空间*J/K#Fc3x/YR-G!i}
2)加载PL/SQL程序包
@Fd/vJ6_ _U X0sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catprocITPUB个人空间[p url,n%l;Q
3)加载数据复制支持软件
nPV&`K{(QZ0sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep
zP1V M`#g}04)加载Java程序包
c/ ||7?qg(O/v x"D0sql>@/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvm
0V0b2XI3{B05)加载系统环境文件
F,TY6k*Dy)p0sql>connect system/pass
GT/{!g ~r)MAk*[;u0sql>@/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld

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

1.确定数据库名、数据库实例名和服务名并创建目录(DBCA创建的脚本不包含建立目录命令,须自己创建)ITPUB个人空间I+MSU0u~5qZ
建立目录命令(下面以 db_name=eygle为例):

mkdir D:/oracle/ora90/cfgtoollogs/dbca/eygleITPUB个人空间}#~Da zu$n!K~
mkdir D:/oracle/ora90/databaseITPUB个人空间N(e5b$_*a,p~;w!x1i9~
mkdir d:/oracle/admin/eygle/adump
W#ht*w nI0mkdir d:/oracle/admin/eygle/bdumpITPUB个人空间2z5K FD/G
mkdir d:/oracle/admin/eygle/cdump
)l }/]n9mj*w _J0mkdir d:/oracle/admin/eygle/dpdump
jG)KM;j0mkdir d:/oracle/admin/eygle/pfile
+B:i:}-Vf$x2l0mkdir d:/oracle/admin/eygle/udumpITPUB个人空间5qM&s;F0~;eX)Vf2@"p
mkdir d:/oracle/flash_recovery_areaITPUB个人空间 tR/S [K0_ T,G"P
mkdir d:/oracle/oradataITPUB个人空间9@[&mV-A F}
mkdir d:/oracle/oradata/eygle

2.创建参数文件ITPUB个人空间eo{Bq(b
在Windows下的参数文件名称及路径如下:
LCzL[ U(c0d:/oracle/product/10.1.0/admin/DB_NAME/pfile/init.ora(oracle10g)ITPUB个人空间2E,RC"K%n$z#e(F
d:/orant/database/iniORACLE_SID.ora(oracle7,oracle8)ITPUB个人空间F6ou|Q OmipVI
参数据文件内容与前述一致。这里不再说明。

3.选择数据库实例ITPUB个人空间p1pRqQMt
设置环境变量ORACLE_SIDITPUB个人空间6h m-S2R y}Mt
c:/>set ORACLE_SID=数据库实例名

4.创建数据库实例ITPUB个人空间 /btE1O T
在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,可以在操作系统符号下直接运行。直接输入oradim显示此命令的帮助。
K5{?C9Hz7?0c:/>OradimITPUB个人空间)R^RPL
下面对Oradim命令的参数进行一个说明ITPUB个人空间5~N bP%_s B
-------------------------------
B#JZN_+DX/x ur0-NEW 表示新建一个实例ITPUB个人空间f{5S9[!E K
-EDIT 表示修改一个实例ITPUB个人空间HhV1M7{ P,{*v
-DELETE 表示删除一个实例
4/D2LP%v$Ta0-SID sid     指定要启动的实例名称
,Ie#tE#c E D Eo-N)S B0-SRVC service 指定要启动的服务名称
6sq'c.K E@$f0-INTPWD password 以Internal方式连接数据库时的口令字
{0qH8C/ZPB4t"MK[&J0k0-MAXUSERS count 该实例可以连接的最大用户数
X$gs*n3B8~1^0-USRPWD password 指定内部用户的口令,如是作为Windows管理登录,不用此参数
Nic9D {4p0-PFILE pfile     该实例所使用的参数文件名及路径
'u9r;~ _/_ z!M}0-STARTTYPE srvc|inst|srvc,inst 启动选项(srvc:只启动服务,inst:启动实例,服务必须先启动,srvc,inst:服务和实例同时启动)
^*@K{#j f-a%j0-SHUTTYPE srvc|linst|srvc,inst 关闭选项(srvc:只关闭服务,实例必须已关闭,inst:只关闭实例,srvc,inst:服务和实例同时关闭)
&`4ss-W2@3|0-STARTMODE a|m 创建实例所使用的模式(a:自动,即windows启动时自动启动 m:手动)ITPUB个人空间9r pR*?6Hr8U!b
-SHUTMODE a|i|m 关闭实例时所使用的模式(a:abort异常方式,i:immediate立即方式,n:normal正常方式)ITPUB个人空间L1V3~Z.^r&I8c
----------------------------ITPUB个人空间2Tv-iUP%H8tV-L
例:创建一个数据库实例
-ZC7fs*C0c:/>oradim -NEW -SID myoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"
7A2ZR.LhG({8k0
/gv)MV2M*q#l0c:/>oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"ITPUB个人空间 `iW:J0Q#p8[k?
例:修改一个数据实例
J-?-J3m,p7p0c:/>oradim -EDIT -SID myoracle -STARTMODE a
[VnN;v:Uk^n1V0ITPUB个人空间#G;Hg8Dxg
c:/>oradim -EDIT -SRVC OracleServicemyoracle -STARTMODE a
C4WDeT//OA%P0例:删除一个实例ITPUB个人空间^G&gwsE'j[
c:/>oradim -DELETE -SID myoracleITPUB个人空间SA9u7]}9q&H~
ITPUB个人空间dA&J,l5l A%HP
c:/>oradim -DELETE -SRVC OracleservicemyoracleITPUB个人空间Ej/Zq"L$Pa(K7mQ:d
例:启动服务与实例ITPUB个人空间-A1N.^s'wN x(K
c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvc,inst
5vR8h;c$Z8}VLiZ0只启动服务
l'V7M0o mS8{0c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvcITPUB个人空间 h7PS2n#X
启动实例:
sU2Q5ZJTF"{J}v0c:/>oradim -STARTUP -SID myoracle -STARTTYPE instITPUB个人空间 t5yH)B8H
例:关闭服务与实例
hG*O Q}/P_/ b%O Q0c:/>oradim -SHUTDOWN -SID myoracle  ITPUB个人空间7lh,a+u ni r,`h
c:/>oradim -SHUTDOWN -SID myoracle -SHUTTYPE srvc,inst

5.启动实例并创建数据库ITPUB个人空间@+Sn/-`Z4y./
c:/>oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:/fangys/initmyoracle.ora
"g$J9}&^/-M0c:/>set ORACLE_SID=myoracleITPUB个人空间g*eVf a'W R b:Z
c:/>sqlplus sys/syspass as sysdba
Y~X7C0@o'J$Mo?0sql>startup -pfile=d:/fangys/initmyoracle.ora nomount
#Tv}3Q3E N1PM'C0sql>CREATE DATABASE myoracle
sC1W:?4v@0logfile group...
:T"N*u0D'`3H0...

6.创建数据字典ITPUB个人空间|1B6l#N-?l_"gY
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catalog.sql;
mfD)n2{.B[o0sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catproc.sql;ITPUB个人空间Jc+BQEbP$I vhU
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catrep.sql;ITPUB个人空间 o/}5dh(L Lxz ?
sql>@d:/oracle/product/10.1.0/db_1/javavm/install/initjvm.sql;
;XZf,L2Ik2@0sql>@d:/oracle/product/10.1.0/db_1/sqlplus/admin/ppbld.sql;

 

一、启动数据
E jfh |7x+/ T0
$sqlplus "sys/pass as sysdba"ITPUB个人空间+~z7D6Y;?Z.x t
sql>startup

二、启动监听器ITPUB个人空间)wqp"M:}k
  数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。监听进程的启动方法为:
3?0}m^ F!S0RP0$lsnrctl start
3~K%i'^(l?2/)q0在widnows中,可以从服务列表中启动监听器。
CO6t:u'oK$|%b~!h#O0监听里程配置文件为listener.ora,位于目录/home/app/oracle/product/10.1.0/db1/network/admin/。ITPUB个人空间F:Z0jc6H
此配置文件分为两部分,一部分为监听程序本身的配置,包括协议,地址,端口号等;另一部分为监听程序所连接的数据库的实例信息,包括:实例名,全局数据库名,oracle主目录等。监听器可以利用oracle net config 向导来配置。
rX#Yx9_`6O0要显示监听器的运行状态:$lsnrctl status;
N/oh2y2up0要停止监听器:$lsnrctl stop。

三、数据库的启动过程
K+Ur8Iw0分为三个阶段:ITPUB个人空间&[h.oH1_(M
1. 启动实例,包括以下操作:ITPUB个人空间}0ju/V,Z,/6_,h,}R9/b&y(v
1) 读取参数文件
y*O r9j?:T2m02) 分配SGA
wRt%j Q-uIm03) 启动后台进程ITPUB个人空间#Ng$v'A,|2M,K
2.装载数据库
l(KO[ t0~ /5C0装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。ITPUB个人空间,_:C)wF4Q
3.打开数据库ITPUB个人空间 ?P] {i{
此步骤使用数据库可以进行正常的操作的处理。主要是打开控制文件,数据库文件和日志文件。

四、数据库启动参数
p)`/Bi6GHKpL01.NOMOUNT:只启动实例,不装载数据库
,DGa(i+A D"|0sql>startup nomount
5N+~(P|mZ1Xk@:f6s02.MOUNT:启动实例,并装载数据,但不打开数据库
(t,e_6BP0Pim0sql>startup mountITPUB个人空间"h8em/__.g
3.READ ONLY:将数据库置为只读ITPUB个人空间}"B)SO$A!Z-v q#G'V
sql>startup mount
-kk9V$XyF0sql>alter database open read only
V/g@!qI5I04.READ WRITE:以可读写方式打开数据,这是默认方式
,}d"^G EM6R!x0sql>startup mount
,W"S M(]}0sql>alter database open read writeITPUB个人空间0UD Od1k
5.OPEN:打开数据库,这是默认方式ITPUB个人空间0xnj/DsR
sql>startup mountITPUB个人空间E ESc4nO I
sql>alter database open;ITPUB个人空间H dw*{6_i#W
6.RESTRICT:以受限方式打开,只有具有RESTRICTED SESSION权限的用户才可以连接数据库ITPUB个人空间["[)a R2c Q$B
sql>startup restrict
*@ ZM J'?/Jq07.PFILE:启时指定参数文件
!KaRWKeF3u0sql>startup pfile=/u02/user/mypfile.ora
v(y Ww(n8~ ZGb08.FORCE:以强制方式启动数据库
MR/e$L.O /6? I!q3s0sql>startup pfile=/u02/user/mypfile.ora open restrict force

五、数据库的关闭
|K:g |y}$n0
  与启动过程相对应,关闭包括三个过程ITPUB个人空间6~4i?bJ%oo:}3H
1).关闭数据库ITPUB个人空间Z yZ;jdO r
2).卸载数据库ITPUB个人空间"lV#rIGX)EK}
3).关闭数据库实例

1.NORMAL关闭方式ITPUB个人空间8B3I*_-`-u1JT
NORMAL关闭方式是正常关闭方式,是默认关闭方式。在这种关机方式下,数据库服务器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。
m^ };s+ze Z(vbv0SQL>SHUTDOWN NORMALITPUB个人空间)@4@%bh9g-m n!t;xQ
2.IMMEDIATE关闭方式ITPUB个人空间$|,aSm0rPS.n2]J
使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回退,中断连接,然后关闭数据库。ITPUB个人空间&R:tb}9p[*M P dO
SQL>SHUTDOWN IMMEDIATE
S3/'W-e3pPS03.ABORT关闭方式ITPUB个人空间 j+D M5i/x-QNd
ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭,对事务膛数据完整性不作检查。是最快的关机方式。
nd&u&^*H/M#ptC0a9K X0sql>shutdown abort;ITPUB个人空间z"MII,[*io
4.TRANSACTIONAL关闭方式
x_(g Q+w9[^ Z0在这种关机方式中,数据库必须等待所有的客户运行的事务结束,提交或回退。ITPUB个人空间v)h&`0Maf&T*^-z
sql>shutdown transactional

 Oracle数据库的连接结构有三种:ITPUB个人空间:G0KOsU"i*J hR5G4tX
1) 组合用户与服务器结构:在这种连接方式中,客户端与服务器同处一台机器中,对于每一个用户,其库应用程序与服务器程序组合成单个服务器进程。
6cH T7Km*Bb"W02) 专用服务器(DedicatedServer)结构:在这种方式中,对于每一个用户,其数据库应用是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码
9x ic8^4EYMO3N:z03) 多线程服务器(Multithreaded Server)体系结构:在这种方式中,一个或多个客户应用程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一的关系,而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。

专用服务器
I_ Z G1YDz0
*T$nQ`3w%ks%QC//0专用服务器的工作过程:ITPUB个人空间(T,|@6ig
1) 客户端通过oracle net向监听器发连接请求ITPUB个人空间C cKuUU
2) 监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此用户创建一个专用服务器进程ITPUB个人空间0C[|S&pUjE
3) 客户直接与该专用服务器进程进行交互,处理SQL,并且服务器在该会话的PGA中建立一个专用SQL区。
wa"o-c(y@,g;bR0如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora或修改连接描述串。增加关键字“Server=DEDICATED”,如:
Cg.w)q$f0prod=
5Ft/IWv0       (DESCRIPTION=
|`)/;z`,BMp s0         (ADDRESSLIST=ITPUB个人空间M tD)i8k6V| Z
           (ADDRESS=
I}`4nIrP7B0             (PROTOCOL=TCP)(HOST=192.168.0.3)(PORT=1521)ITPUB个人空间?1y3NJ"S*p#Ah V ^
             (SERVER=DEDICATED)
k;M6k,vo0           )ITPUB个人空间:V_ c1k5Zz:EC
         )ITPUB个人空间n"s2N4P|X
         (CONNECT_DATA=(SID=PROD)ITPUB个人空间1_U[ PP,M$L|
        )ITPUB个人空间C;`i!F8MBC
       )ITPUB个人空间TB@4z(w4J;G-A
还必须修改SQLNET.ORA文件,增加“USE_DEDICATED_SERVER=TRUE”

多线程服务器体系结构
x~%q R&~_(h5s0
)gS{*H] D |-@sO0专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支 持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立连接的过程,以级与建立专用服务器连 接过程的不同:ITPUB个人空间 ~ l:u|#Kc j
1) 客户通过网络与监听器联系ITPUB个人空间3]E'j3E8H
2) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客户请求导向相应的调度程序。ITPUB个人空间:w|S|V d%hj
3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。
5R:_C%w-}@0uh04) 一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接将操作请求发送给高度程序。
.aS6U!/!y05) 调度程序将客户请求放在SGA的请求队列中。ITPUB个人空间h3O1AKDx
6) 下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。ITPUB个人空间//K[0E.HX i
7) 共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中。ITPUB个人空间3r u$y3`vtg
8) 调度程序从响应队列中读取数据并将结果送组客户。

ITPUB个人空间.pTV7p} LNH
  有几个概念在这里作个补充说明:
$k1gN(/ f x~+F.q0
1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。ITPUB个人空间/#TO;bC$[
2) 调度程序(dispatcher):在MTS体系结构中,监听器与调度程序联系,调度程序负责调度MTS中的各个共享服务器进程。


FVH s7v5w0 多线程服务器的设置参数有:ITPUB个人空间)z Hm9m"S6rCS
MTS_SERVICE:多线程服务器名称,一般为数据库名ITPUB个人空间/Tm3u7jf5ls
MTS_DISPATCHERS:初始调度器个数
hk/?9y De/U;lZ.^0MTS_MAX_DISPATCHERS:调度器最大个数ITPUB个人空间(kl0g"W Mw/p
MTS_SERVERS:共享服务器个数ITPUB个人空间;Z-v+I u2`
MTS_MAX_SERVERS:最大共享服务器个数ITPUB个人空间+j,V6}Q3_a
多线程服务器的设置是通过对以上各个参数的设置完成的。格式如下:ITPUB个人空间#Q@9h%/g
MTS_SERVICE=RSITPUB个人空间KX8SvQ.g{
MTS_SERVERS=10
'mAPXM/n0MTS_MAX_SERVERS=100ITPUB个人空间-]:sIQ1HD!c
MTS_DISPATCHERS="(PROTOCOL=TCP)(POOL=YES)(MULT=YES)"ITPUB个人空间N L/i+_;fg|
MTS_DISPATCHERS="(PROTOCOL=IPX)(POOL=YES)(MULT=YES)"
1p}*z5V5t$M0MTS_DISPATCHERS="(PROTOCOL=IPC)(POOL=YES)(MULT=YES)"
'HY/eDkkSi0MTS_MAX_DISPATCHERS=100


c6e(pP8A)~2X3V1U0有关多线程服务器的数据字典如下:ITPUB个人空间P$y&R:Cl H^rl
V$MTSITPUB个人空间b*p e#`5]&T8y!z,o7~
V$DISPATCHER
+Kp}RB R0V$SHARED_SERVERITPUB个人空间 lyx8n(r9hh
V$CIRCULT
*ysHJ~/[U0各字典的详细说明请参考Oracle文档。

第八篇 再述oracle数据库体系结构 之四:Oracle实例的进程结构

  这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。ITPUB个人空间5d&V(z-^ Kr$VTNl
Oracle实例由内存区域和后台进程组成。ITPUB个人空间I!@.w;]/-F
Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取)和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进程,允许多个用户同时使用)。
z Fdl*j1y C0在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下面的说明)外,还有其他后台进程,包括:Dnnn, DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参数 PROCESS设定的值:ITPUB个人空间6E$yp5~ v#L#Sk4p
sql>show parameter processITPUB个人空间XDH2w jN3S0ze"R
     当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程来为这些客户服务,此进程在widnows下表现为线程。 此进程的主要作用有:对于用户发出的SQL语句进行语法分析,编译,执行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到 SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应用程序。下面的语句用来查询数据库中的用户会话信息。
+n6M5]7hW i0sql>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;ITPUB个人空间 I'~Q4wr /R
结果中:
E&Q+N,g3Q5m(?0sid 表示会话ID号,
;Z5icw/K3P0ser 表示会话serial#号,serial#与sid组合以唯一表示一个会话,ITPUB个人空间 j;VCS5b{&g:A`0C xg
spid 表示操作系统进程号,ITPUB个人空间 T8Qevi |g0I
schema 表示数据库用户名,
)TR,|)ig#//dY0h@I0typ 表示进程类型,use为用户进程,bac为后台进程
9a.O:n_&I4F!ig$l/mzA0%hit 表示数据缓冲区命中率,
j#K$S#Ja1i*m|T0cpu 表示使用cpu的时间,ITPUB个人空间%Ep-SJ~
bchng 表示修改了的数据块的个数。

下面介绍各个后台进程。ITPUB个人空间R3UN'u!WH
1. DBWR进程
7K W#h4q!}%k7y0DBWR(Database Writer)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。ITPUB个人空间wK H%j@
当数据缓冲区中的一个数据被修改后,被标记为“脏”,DBWR进程负责将“脏”数据写入磁盘。
9sKg$a1yJ+[2J8G ]AV0DBWR采用LRU算法来替换数据缓冲区中的数据。ITPUB个人空间!g^?}HA
DBWR的作用包括:
;t(QO_C#B01) 管理数据缓冲区,以便服务器进程总能找到空闲缓冲区ITPUB个人空间i]C[a`9s9t
2) 将所有修改后的缓冲区中的数据写入数据库文件ITPUB个人空间Q:Cs'F;e^*@pt
3) 使用LRU算法将最近使用过的块保留在内存中ITPUB个人空间:~-Lh6?0o:L
4) 通过延迟写来优化磁盘i/o.ITPUB个人空间ls2FF#C]!g
在下列情况下DBWR要将脏数据写入磁盘数据文件:
6U3F4l b`h01) 当一个服务器进程将缓冲数据块移“脏表”,面该脏表达到一定程度进。(该临界长度由参数DB_BLOCK_WRITE_BATCH决定)
8~}? a{)U_02) 当一个服务器进程在LRU表中查找DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空闲的缓冲区ITPUB个人空间!m+~P*F [5Zq"b7}E ]
3) 出现超时
4aG6i3Q E^8O2[04) 检查点发生时ITPUB个人空间;g/J%ZKy6I
在一个Oracle实例中,允许启动多个DBWR进程,DBWR进程个数由参数DB_WRITE_PROCESSES指定,上限为20,进程名依次自动命名为:DBW0,DBW1,DBW2...DBW19。
X$n!wvgM X+y.F0sql>show parameter processes

2. LGWR进程
OJOd+U$j$v0LGWR(Log Writer)进程将日志数据从日志缓冲区中写入磁盘日志文件中。ITPUB个人空间7| QRiA.fE.t8A5y,M
关于LGWR进程的工作时机可以看我写的第一篇《一次事务过程》。ITPUB个人空间j7hgE+c /;~)P4mH+O9y q i
LGWR的写盘条件是:ITPUB个人空间 y8c0]F o6A
1) 发生提交,即commit;
_hW.ty X02) 日志缓冲区达到总数的1/3时;
#s0I+C'j ]*W03) 超时;ITPUB个人空间#Rp aAWf
4) DBWR进程需要为检验点清除缓冲区时。ITPUB个人空间+f1e1Qf4XIKU9g
每一个Oracle实例只有一个LGWR进程。
`:Pqu O0LGWR将日志信息同步的写入到日志文件组的多个日志成员中,如果组中的一个成员文件被删除或不可使用,LGWR将日志信息继续写到该组的其他文件中,不影响数据库的运行。

3. SMON进程ITPUB个人空间3]:v4Bo.Y}`D
SMON(System Monitor),系统监控进程,在实例启动时执行实例恢复,并负责清理不再使用的临时段。

4. PMON进程
Rt?g_/&|$Or*fq0PMON(Process Monitor),进程监控里程,在服务器进程出现故障时执行进程恢复,负责清理内存内存和释放该进程所使用的资源。

5. ARCH进程ITPUB个人空间%oo GZ? a%e-P
ARCH(Archive Process,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质失败时的恢复。ITPUB个人空间r-[!`V E6eE
日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组,日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。
3MmZ~cMQ8f)^.VF,x0在一个数据库实例中,归档进程最多可以启动10个,进程名依次自动命名为ARC0,ARC1,ARC2...ARC9,设置方法是:在参数文件中增加 参数LOG_ARCHIVE_MAX_PROCESSES。关于如何启用数据库的自动归档,在前面的《物理结构》一篇中已有说明,这里说明一个几个相关的 参数:
g'A6g&m%R2c01) LOG_ARCHIVE_DEST:用于设置归档日志的文件存储目录ITPUB个人空间5B7slvK1WE/t
2) LOG_ARCHIVE_DUBLEX_DEST:用于设置归档日志文件的镜像存储目录,此参数在oracle 8及以上的版本中支持ITPUB个人空间]R+U7q&`
3) LOG_ARCHIVE_DEST_n:用于设置更多的镜像目录,其中,1<=n<=10,该参数有以下三个选项:ITPUB个人空间4p E!E_ hV:O
(1)MANDATORY:表示必须完成此目录的归档,才可以切换。ITPUB个人空间-men6E(l,G
(2)REOPEN:归档目录或介质失败后,需等多长时间能重新写入日志,默认时间为300秒。ITPUB个人空间0v&QL}~g9Ay;fr?
(3)OPTIONAL:不管是否归档完成都进行切换,这是默认方式
Hp0E1g!/0举例如下:ITPUB个人空间hD#l:cD1vc
LOG_ARCHIVE_DEST_1='LOCATION=/u01/oracle/archive/ITPUB个人空间e]-M/hk1@:gn7i
                       MANDATORY
5t8Og!o{4N F0                       REOPEN=500'
cLA.B8k a#`0LOG_ARCHIVE_DEST_2='LOCATION=/u02/oracle/archive/
je$k;s"vg0                       OPTIONAL'ITPUB个人空间Cd1I ~O-/
LOG_ARCHIVE_DEST_n只适用于oracle 8i及以上的版本。
Ry] [6K9i6R04) LOG_ARCHIVE_DEST_STATE_n:用于对归档日志目录进行失效或生效,该参数与LOG_ARCHIVE_DEST_n一一相对应。如:ITPUB个人空间3@TR ^b[ eR
LOG_ARCHIVE_DEST_STATE_1=DEFER
FDq(? zJ| Gv1n0LOG_ARCHIVE_DEST_STATE_2=ENABLE
'_(t+E3@'T?n(Qk0此参数可以在线设置:ITPUB个人空间.L"{mh7G E6e%N
sql> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1=DEFER;
+tljmx3TRB#S/0此参数只适用于oracle 10g及以上版本。

6. CKPT进程
`L DoC p0CKPT(CheckPoint,检查点)进程出现时,系统对全部数据库文件及控制文件的文件头的同步号进行修改,以保证数据库的同步。ITPUB个人空间N$?*v%aD1G
以下两个参数是对CKPT有影响的:
[H5}^M?0LOG_CHECKPOINT_TIMEOUT:决定产生一个检验点的时间间隔,单位为秋,默认为1800;ITPUB个人空间!U4D3@$ZT
LOG_CHECKPOINT_INTERVAL:执行一个检验点需要填充的日志文件块的数目,默认为0,表示不起作用。
n7C7c{mD'D!yE"U0系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步依据,同时存储在这三个中,在系统改变时,检验点号也会同时改变。
l;q0I Ik Y*~G e^6E)Pm0引起CKPT产生的主要时机有:ITPUB个人空间` m5~g"_
1)日志切换时
Du m8T)gv d02)达到LOG_CHECKPOINT_TIMEOUT指定的间隔时间ITPUB个人空间$h(_9kc"xG K#r
3)达到LOG_CHECKPOINT_INTERVAL指定的日志块数
m"|NHJ`z04)数据库关闭
$oI&^ OM05)DBA强制产生ITPUB个人空间 c%OGZV PkW
6)表空间OFFLINE时

7. RECO进程ITPUB个人空间 NFPZZ.K-G/b
RECO(Recover,恢复)进程用于分布式数据库系统,RECO进程自动地解决在分布式数据库中的事务故障。

8. LCKn进程
s'lM&Ee aECs1k ]0LCKn(锁进程)用于Oracle并行服务器环境下,用于多个实例间的封锁,该进程最多可以启动10个。

9. Dnnn进程ITPUB个人空间}au:WF
Dnnn(Despatcher,调度)进程。用于多线程服务器体系结构中。详见下一篇《Oracle连接配置结构》

10. SNP进程
%W)KEvU$o0SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自动刷新,并同时通达DBMS_JOB程序包自动运行预定的存储过程,SQL,PL/sql程序等。有两个参数用来控制作业进程的计划:ITPUB个人空间6wd^3M{"l n dj Z
1) JOB_QUEUE_PROCESS:用于设置作业进程个数ITPUB个人空间V^nye4f(G"L
2) JOB_QUEUE_INTERVAL:用于设置作业进程被周期性唤醒的时间间隔

后台进程跟踪信息ITPUB个人空间Uh7Yi4K ^
所有修改数据库结构的命令会自动被后台进程跟踪记录,跟踪信息由oracle后台进程自动存储,跟踪文件的名称为alter_SID。此文件的存储目录由参数BACKGROUND)DUMP_DEST指定。
o*P(S?u$[0可以用工具命令TKPROF来格式化跟踪文件,如:ITPUB个人空间H7l vin
$tkprof oralogfile1.logITPUB个人空间'dmd;s:R8Qw7zR
除了跟踪后台进程外,还可以启用参数SQL_TRACE对用户的语句进行跟踪。修改参数文件:ITPUB个人空间u?^.Y2G;jK
TIMED_STATISTICS=TRUEITPUB个人空间(Qlae xe,A
USER_DUMP_DEST=目录名
x7K.{+?y0MAX_DUMP_FILE_SIZE=5M
O7Uq#c{#n'{5o0SQL_TRACE=TRUEITPUB个人空间 l+tVop,F {S'~
或者:
%M"A$uJb oS0SQL>ALTER SESSION SET SQL_TRACE=TRUE对当前会话进行SQL跟踪。

锁等待问题与KILL SESSION
9/ COz6c!|:~/sWgEM0为了保证数据的一致性,系统提供锁机制。有关锁的概念可以参数《数据库系统概论》一书。要了解当前在等待锁资源的用户:
#[h_'?w(M!]0sql>select a.username,a.sid,a,serial#,b.id1 from v$session,v$lock where a.lockwait=b.kaddr;ITPUB个人空间{PXTs"gf K
要了解锁住其它用户的用户进程:
ZK d/(wh$iR0SQL>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;

原创粉丝点击