Oracle 五大重点名词解析

本人系统学习ORACLE初期,对数据库的5大重要名称概念认识不是很深刻,搜到了一篇感觉比较好的文章,在这里分享给所有与我一样的初学者。有些与作者观点出入的地方标注了一下。分享出处:http://space.itpub.net/9390331/viewspace-659760

数据库名、实例名、数据库域名、全局数据库名、服务名 ,
这是几个令很多初学者容易混淆的概念。相信很多初学者都与我一样被标题上这些个概念搞得一头雾水。我们现在就来把它们弄个明白。

一、数据库名
b5}u6[ N*G[0什么是数据库名?

Z-~kuJ!s6]i0数据库名就是一个数据库的标识,就像人的身份证号一样。他用参数DB_NAME表示,如果一台机器上装了多全数据库,那么每一个数据库都有一个数据库名。在数据库或创建完成之后,参数DB_NAME被写入参数文件之中。格式如下:
z9a{]$?]8\0DB_NAME=myorcl
d-iN r6Qd [+v0...ITPUB个人空间`n(o'u4Us5M\
在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。因为,数据库名还被写入控制文件中,控制文件是以 二进制型式存储的,用户无法修改控制文件的内容。假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。但是在启动时,由于参数文 件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。

数据库名的作用
R QJEam0GtU0数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、与恢复数据库时都需要使用到的。
cBUH8U \]n/]:H&g0有很多Oracle安装文件目录是与数据库名相关的,如:ITPUB个人空间p JL2`E }
winnt: d:\oracle\product\10.1.0\oradata\DB_NAME\...ITPUB个人空间AF9{6@4J'O d
Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/...ITPUB个人空间 D^,|aSV!J:F:j\e
pfile:ITPUB个人空间-b8`0j3A0sR
winnt: d:\oracle\product\10.1.0\admin\DB_NAME\pfile\ini.oraITPUB个人空间YpK5z/h Z_
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.oraITPUB个人空间:_hW5W0~_5NK x
跟踪文件目录:ITPUB个人空间KdN1QG&zH$f"}
winnt: /home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...ITPUB个人空间4a!H`/uUml
另外,在创建数据时,careate database命令中的数据库名也要与参数文件中DB_NAME参数的值一致,否则将产生错误。
9ty"`|0E+u+Q0同样,修改数据库结构的语句alter database, 当然也要指出要修改的数据库的名称。
b8|,l#{[;hVr0如果控制文件损坏或丢失,数据库将不能加载,这时要重新创建控制文件,方法是以nomount方式启动实例,然后以create controlfile命令创建控制文件,当然这个命令中也是指指DB_NAME。ITPUB个人空间M@wf Aw.p.[
还有在备份或恢复数据库时,都需要用到数据库名。
B+m nO` L0总之,数据库名很重要,要准确理解它的作用。

查询当前数据名ITPUB个人空间 wy8@H7~"EAp7aA
方法一:select name from v$database;ITPUB个人空间wK~8o)aB9z(h&x^
方法二:show parameter dbITPUB个人空间 ],K!mT[u
方法三:查看参数文件。

修改数据库名
X kU;`%E t#x'?X0前面建议:应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是一件比较复杂的事情。那么现在就来说明一下,如何在已创建数据之后,修改数据库名。步骤如下:
r7T/k Q1m/|C01.关闭数据库。
%Z0M \`s0R(vqU02.修改数据库参数文件中的DB_NAME参数的值为新的数据库名。
$_$] Ae,T03.以NOMOUNT方式启动实例,修建控制文件(有关创建控制文件的命令语法,请参考oracle文档)

二、数据库实例名ITPUB个人空间K l(|&xe+D'i5_?,F3{
什么是数据库实例名?
:_!_~#n!H6tZ0
数据库实例名是用于和操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。实例名也被写入参数文件中,该参数为instance_name,在winnt平台中,实例名同时也被写入注册表。ITPUB个人空间+Dl p:IP `n5NLk
数据库名和实例名可以相同也可以不同。
4?_7\/? fi-_4`0在一般情况下,数据库名和实例名是一对一的关系,但如果在oracle并行架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。这一点在第一篇中已有图例说明。

查询当前数据库实例名ITPUB个人空间2y{!X5P:c ]$`1a hq n
方法一:select instance_name from v$instance;
1t'CAVD7gk1l~0方法二:show parameter instanceITPUB个人空间;`H1Vv Tv.e
方法三:在参数文件中查询。

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

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

三、数据库域名ITPUB个人空间 w n~(C KVe
什么是数据库域名?
ITPUB个人空间tf;L6mA8V6k ni-e
在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于oracle分布式环境中的复制。举例说明如:
zZqK9Y1F0全国交通运政系统的分布式数据库,其中:ITPUB个人空间3y#n-l.? U1T"O| O{
福建节点: fj.jtyz
.xch4Z,ldr0福建厦门节点: xm.fj.jtyzITPUB个人空间B4i1nZmAoq
江西: jx.jtyz
{!g8}9})q`$@.C0江西上饶:sr.jx.jtyzITPUB个人空间1Y*R5yywfW7e'y3}tH
这就是数据库域名。ITPUB个人空间*jr3F0@Pu:oj Bs
数据库域名在存在于参数文件中,他的参数是db_domain.

查询数据库域名
Q o(tgEuo0方法一:select value from v$parameter where name = 'db_domain';ITPUB个人空间]+FuJ x:dA&U
方法二:show parameter domainITPUB个人空间GpJydf
方法三:在参数文件中查询。

全局数据库名
Vrt`sx}0Ym6q0全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:oradb.fj.jtyz

四、数据库服务名
)e0cI$I0px0什么是数据库服务名?
d c1w&{9cY#w0
从oracle9i版本开始,引入了一个新的参数,即数据库服务名。参数名是SERVICE_NAME。
6~0P1K"rqp0如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。(注:服务名不一定与数据库名一致。可以更改。其作用主要是用于他人配置服务名,想访问本机数据库时可以使用。例如ALTER SYSTEM SET SERVICE_NAME=B,C。此时本机就增加了两个服务名B和C)

查询数据库服务名
-qF?r_.t^r8Z0方法一:select value from v$parameter where name = 'service_name';ITPUB个人空间q0lw/T|
方法二:show parameter service_nameITPUB个人空间%z wt$m3`A S:[
方法三:在参数文件中查询。

数据库服务名与网络连接ITPUB个人空间9y gM0x`R ]
从oracle8i开如的oracle网络组件,数据库与客户端的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名 ITPUB个人空间2t4H]0K4N X/jm*q:DdMD

0ba @N#e!iF0

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

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

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

一、在Unix下创建数据库
b.]ST(htOn01.确定数据库名、数据库实例名和服务名
$rk*[/k)bFw F,t[F0关于数据库名、数据库实例名和服务名,我之前有专门用一篇来详细介绍。这里就不再说明了。

2.创建参数文件ITPUB个人空间Ce)E h:B4vh
     参数文件很确定了数据库的总体结构。Oracle10g有两种参数文件,一个是文本参数文件,一种是服务器参数文件。在创建数据库时先创建文本参数文件, 在数据库创建后,可以由文件参数文件创建服务器参数文件。文本参数文件的取名方式为initORACLE_SID.ora,其中,ORACLE_SID是 数据库实例名。其名称及路径为:
@w h1N'c7L"^ z E^0/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.ora
br]^/jUHB`0其中,DB_NAME为数据库名。所以,应创建一个以之命名的目录,并将文本参数文件存放在上述目录中。假设新创建的数据库名为MYORACLE,SID与数据库名一致。则上述目录实际为:ITPUB个人空间AC"i!R,x3N
/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.oraITPUB个人空间!Pr*r#gu7jk1F!r
1)参数文件的介绍
Lx4o#K2K)tJ0参数文件决定着数据库的总体结构,用于设置数据库的近260个系统参数。下面分类别说明一下各参数的作用,关于参数的详细使用说明请参考Oracle官方参考文档。ITPUB个人空间L&{)L\!F Jq6U1U;_
a.数据库标识类参数
M{hdE-~9U.Pl0
DB_NAME: 数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制文件ITPUB个人空间4v%S3g6J$^6L:O*[
DB_DOMAIN: 数据库域名,用于区别同名数据库。数据库名与域名一起构成了全局数据库名
e:U*VR.V A*A$tv+w0INSTANCE_NAME: 数据库实例名,可以与数据库相同ITPUB个人空间BO+qPe;K/`]{
SERVICE_NAMES: 数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名ITPUB个人空间:x8oG3Z4_zi
b.日志类参数
`O/P}y0[0LOG_ARCHIVE_START: 是否启动自动归档进程ARCH
lU:{5g W E q v#ES0LOG_ARCHIVE_DEST: 归档日志文件存储目录ITPUB个人空间!JF/o4{Mbu*oW i]&X
LOG_ARCHIVE_FORMAT: 归档日志文件的默认文件存储格式ITPUB个人空间wI'`4LW
LOG_ARCHIVE_DUPLEX_DEST: 归档日志文件镜像存储目录(Oracle8以上)ITPUB个人空间~'hy!}4}U6g q9M
LOG_ARCHIVE_DEST_n: 归档日志文件存储目录(Oracle8i以上)
7[1N!iG0Z:t'O/xq0LOG_ARCHIVE_DEST_STATE_n: 设置参数LOG_ARCHIVE_DEST_n失效或生效
)Gv"z7K/l3S0LOG_ARCHIVE_MAX_PROCESSES: 设置自动归档进程的个数
E7u*e@,f%[0LOG_ARCHIVE_MIN_SUCCEED_DEST: 设置最少的成功归档日志存储目录的个数ITPUB个人空间)R1Q%oms
LOG_CHECKPOINT_INTERVAL: 根据日志数量设置检验点频率
+r'o*JvcLPQ7[0H0LOG_CHECKPOINT_TIMEOUT: 根据时间间隔设置检验点频率
0Anw'O7pA;b b0c.内存管理参数ITPUB个人空间*FR%jz&h3~3x
DB_BLOCK_SIZE: 标准数据块大小ITPUB个人空间;JK~&b [2W
DB_nK_CACHE_SIZE: 非标准数据块数据缓冲区大小
SK#Gg!{8E[D M'b0SHARED_POOL_SIZE: 共享池大小控制参数,单位为字节
pO,fM] b)k A%w-^0DB_CACHE_SIZE: 标准数据块数据缓冲区大小
7n+gj2C%hNI7wC0DB_BLOCK_BUFFERS: 数据缓冲区大小,9i之后已放弃使用
_%f(Y y{\Q1z0LOG_BUFFER: 日志缓冲区大小
;y eV8Z c'l+T#S+N0SORT_AREA_SIZE: 排序区大小ITPUB个人空间 Q`(_Og)tg%a
LARGE_POOL_SIZE: 大池大小ITPUB个人空间)rP0_-q nu
JAVA_POOL_SIZE:池大小
*N:\@Z(O}/X0d.最大许可用户数量限制参数
Z(@ s4N&[/p0
LICENSE_MAX_SESSIONS:数据库可以连接的最大会话数ITPUB个人空间/\f?A%J1k(Y
LICENSE_MAX_USERS:数据库支持的最大用户数
S|,f0a^P.A0LICENSE_MAX_WARNING:数据库最大警告会数(会话数据达到这个值时,产生新会话时就会产生警告信息)
s7{ B*@-VE0e.系统跟踪信息管理参数ITPUB个人空间1Ug Y^#jh,[ ix&v(X`
USER_DUMP_DEST:用户跟踪文件生成的设置
w.]5H+I^0BACKGROUND_DUMP_DEST:后台进程跟踪文件生成的位置
l2c1k~A mj7Pgp0MAX_DUMPFILE_SIZE:跟踪文件的最大尺寸
1MQ*Cu%A4Ur0f.系统性能优化与动态统计参数ITPUB个人空间 u/N)lsw@ s
SQL_TRACE:设置跟踪ITPUB个人空间nJD ] lp t$U&S6]a
TIMED_STATICS:设置动态统计ITPUB个人空间aD+v~ih`
AUDIT_TRAIL:启动数据库审计功能
vci7@B]a0g.其他系统参数
"m}anv2?/p0CONTROL_FILES:控制文件名及路径ITPUB个人空间3n EV2b)e
Undo_MANAGMENT:Undo空间管理方式
iT.D| I$}iaVF0ROLLBACK_SEGMENTS:为这个例程分配的回退段名
W,? ia9fFe0OPEN_CURSORS:一个用户一次可以打开的游标的最大值ITPUB个人空间 E zQVpcpXv
PROCESSES:最大进程数,包括后台进程与服务器进程ITPUB个人空间'sz jKGi5l9M
IFILE:另一个参数文件的名字
wnrk2f2{"[]0DB_RECOVERY_FILE_DEST:自动数据库备份目录ITPUB个人空间 nhS^V!W~P7[y
DB_RECOVERY_FILE_SIZE:数据库备份文件大小ITPUB个人空间F(P5_ Zc7SW
2)参数文件样式
2@2FA!~ ` th7pU+SY0
db_name=myoracleITPUB个人空间B]*W,d2f/I
instance_name=myoracle
#k&J"EoPE0db_domain=fangys.xiya.com
ja!kE,h? O:{V0service_names=myoracle.fangys.xiya.com
D6^$yI&B]0control_files=(/home/app/oracle/product/10.1.0/oradata/myoracle/control01.ctl,
V%Vg&@._([#J;i0                  /home/app/oracle/product/10.1.0/oradata/myoracle/control02.ctl,
m3Jv%{pF0                  /home/app/oracle/product/10.1.0/oradata/myoracle/control03.ctl)ITPUB个人空间-P;do7G'c,o
db_block_size=8192
%bN yb;t0user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udump
`,U/_'h Z'P!G7A,e7`8O0background_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdump
.vl,{|W&}0core_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdump
k:|'~ \X&d,z0db_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_area
#@2[yf7q8a0db_recovery_file_size=100GITPUB个人空间!Ko:`]q]&|
...


-C d R(Q#g1a"{03.设置操作系统参数
j+@-E#t:_;KZC5W0$ORACLE_SID=myoracle
:ppxo^T'W&b0$export ORACLE_SID

4.启动实例并创建数据库
D+S/V/\xc;p0
在创建数据库之前,首先要以新的数据库参数启动数据库实例,因为这时数据库的控制文件还没有产生,不能MOUNT或OPEN数据库。启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。ITPUB个人空间(E'j3e5iKT)xZV(j
$sqlplus "sys/pass as sysdba"

sql>startup nomountITPUB个人空间;_ JQ\+~VZ [BU
如果参数文件不在规定的目录中,可以在启动实例时指定参数文件
E-GL]4tqht&x0sql>startup pfile=/export/home/user/initmyoracle.init nomountITPUB个人空间 dNt A7U`5L
在实例启动后就可以使用CREATE DATABASE命令创建数据。其详细语法请参考Oracle官方SQL参考文档。这里以实例来介绍:
{X+G2NT l8\`{0sql>CREATE DATABASE myoracle
J1@)_6D+A{0       MAXINSTANCE 1ITPUB个人空间!X(n0RmY
       MAXLOGHISTORY 216ITPUB个人空间f1vS;p3FD
       MAXLOGFILES 50ITPUB个人空间C"B5v3W+} mJg u
       MAXLOGMEMBERS 5
9j7X8MWrEu0DATAFILE'/home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf' SIZE 500m
v[f!v,@"i)_9S0AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDITPUB个人空间8K1An(P{8ii6f
LOGFILE
D/Wh&^]K0       GROUP 1('/home1/app/oracle/product/10.1.0/oradata/myoracle/log1a.log',ITPUB个人空间J3F9k5r,@ F K
               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log1b.log') SIZE 10m,ITPUB个人空间7Zb7i#}%\S+Z1EOI
       GROUP 2('/home1/app/oracle/product/10.1.0/oradata/myoracle/log2a.log',
fD[k+J@0               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log2b.log') SIZE 10m,ITPUB个人空间(N0{8GiAz|&k,t
       GROUP 3('/home1/app/oracle/product/10.1.0/oradata/myoracle/log3a.log',
1V HA&\2vj.H0               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log3b.log') SIZE 10m,ITPUB个人空间 C2py3`3|v
Undo TABLESPACEundotbsDATAFILE
3c6X9?8w+CY0'/home1/app/oracle/product/10.1.0/oradata/myoracle/undotbs01.dbf' size 200mITPUB个人空间y6U~-RK*nF'u
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDITPUB个人空间 o?@-lR,j6R J
DEFAULT TEMPORARY TALESPACEtempTEMPFILE
R1gg:[Nuaw9wOo z0'/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf' size 325m
^,H-h)@g"x#vg0AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
XG1l9O&y.d P7F:h0DEFAULT TABLESPACEusersDATAFILEITPUB个人空间*IxR]W|O
'/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf' size 1000m
[ UhE ?:x9Jk q)S0CHARACTER SET ZHS16GBK;
'VO@*v3N K?wu0这里说明一下CREATE DATABASE语句的各个关键字的含义:ITPUB个人空间FQT8x rX7j
DATAFILE:SYSTEM表空间的数据文件定义ITPUB个人空间P$Y5]$asX
LOGFILE:日志文件组的定义
a7udYb0Undo_TABLESPACE:重做表空间的定义
&a!@_+|p\,mGT;cU9W0DEFAULT TEMPORTY TABLESPACE:默认临时表空间的定义ITPUB个人空间3nf*K oo
DEFAULT TABLESPACE:默认数据表空间的定义。


0|,s3p ?#e3N05.创建数据字典
B-D.H^L0在数据库创建结束后,数据库自动处于OPEN状态下,这时所有V$××××类数据字典都可以查询。而其它数据字典,如DBA_DATA_FILES、DBA_TABLESPACES等都不存在,必须通过下列骤为系统创建数据字典。
"HbS+oI-VN ^01)加载常用的数据字典包ITPUB个人空间p P-j n"_s@pD
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/catalog
qg@5p3t*k&a02)加载PL/SQL程序包ITPUB个人空间@ P8Vi1D1z ?
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catproc
%^CON_cq03)加载数据复制支持包ITPUB个人空间z mkxv'T+_0wp#p
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep
GiE"i;|m ^\{04)加载Java程序包
7F*}"`4@{~p!T0sql>@/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvmITPUB个人空间.@o;N i#U1O:jG
5)加载系统环境文件ITPUB个人空间9T7u4t9p Ou1QI
sql>connect system/pass
q%L*s m2i0T \Q0sql>@/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld

二、在Windows下创建数据库
RPtN!rb b;j N9e.F0
Oracle实例在Windows下表现为操作系统服务。在windows下,使用命令行方式创建数据的方法有所不同,差别在于在Windows下,需要先创建数据库服务和实例。

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

mkdir D:\oracle\ora90\cfgtoollogs\dbca\eygleITPUB个人空间D(\+cME/Nq&I
mkdir D:\oracle\ora90\databaseITPUB个人空间1f9RV`"g6auRi
mkdir d:\oracle\admin\eygle\adumpITPUB个人空间6CRJ"}daxDZ
mkdir d:\oracle\admin\eygle\bdump
n9}$s%Aa[? D0mkdir d:\oracle\admin\eygle\cdump
a1[3M0j U5aeI{\ a0mkdir d:\oracle\admin\eygle\dpdump
$a3vF0WbQ%Z*e0mkdir d:\oracle\admin\eygle\pfileITPUB个人空间t3[EQ z/}
mkdir d:\oracle\admin\eygle\udumpITPUB个人空间g5k*k K)~%k
mkdir d:\oracle\flash_recovery_areaITPUB个人空间lfFS7m5Z_
mkdir d:\oracle\oradataITPUB个人空间O%K/L4B!GM2H
mkdir d:\oracle\oradata\eygle

2.创建参数文件ITPUB个人空间/S7m2XAb#yE
在Windows下的参数文件名称及路径如下:
\r*d:Aa!?0d:\oracle\product\10.1.0\admin\DB_NAME\pfile\init.ora(oracle10g)ITPUB个人空间-X,Hxj/y5b bZ[/@w
d:\orant\database\iniORACLE_SID.ora(oracle7,oracle8)
7k5wl*Z0PJ0参数据文件内容与前述一致。这里不再说明。

3.选择数据库实例
8}I1ikv,|0
设置环境变量ORACLE_SIDITPUB个人空间R,J~^;O)D;B u)X
c:\>set ORACLE_SID=数据库实例名

4.创建数据库实例
VRh"JuRWs#XJ0
在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,可以在操作系统符号下直接运行。直接输入oradim显示此命令的帮助。
pduGE#b \nOd0c:\>OradimITPUB个人空间bJaN1wbw
下面对Oradim命令的参数进行一个说明
)i;g;gD-q~+z0-------------------------------
3e&EUc"v j0qr`0-NEW 表示新建一个实例ITPUB个人空间!\"m:e i:|&EF
-EDIT 表示修改一个实例ITPUB个人空间 F8V9Wq"gi
-DELETE 表示删除一个实例
_]+W~,O |;X H{$_{0-SID sid     指定要启动的实例名称
mz?+L!UI5fp;m0-SRVC service 指定要启动的服务名称
)mX?s}2l w0-INTPWD password 以Internal方式连接数据库时的口令字ITPUB个人空间5O$K3l*_ w,ek5KT"`
-MAXUSERS count 该实例可以连接的最大用户数ITPUB个人空间:X;~6D7B"?!F8T
-USRPWD password 指定内部用户的口令,如是作为Windows管理登录,不用此参数
#FyJYi&U(e|x[m0-PFILE pfile     该实例所使用的参数文件名及路径
:Fm%Dr]w0-STARTTYPE srvc|inst|srvc,inst 启动选项(srvc:只启动服务,inst:启动实例,服务必须先启动,srvc,inst:服务和实例同时启动)
Yu?5] `OW)u B`+N0-SHUTTYPE srvc|linst|srvc,inst 关闭选项(srvc:只关闭服务,实例必须已关闭,inst:只关闭实例,srvc,inst:服务和实例同时关闭)ITPUB个人空间e!UOCw i \:e0C
-STARTMODE a|m 创建实例所使用的模式(a:自动,即windows启动时自动启动 m:手动)
1L I(gPk Bk1}{y0-SHUTMODE a|i|m 关闭实例时所使用的模式(a:abort异常方式,i:immediate立即方式,n:normal正常方式)
(\3Me:~[ O ]w|$Z!?0----------------------------
A8l.f?4|bR'xq:lZE4W0例:创建一个数据库实例ITPUB个人空间2EO {O4{;OXt
c:\>oradim -NEW -SID myoracle -STARTMODE m -PFILE "d:\fangys\initmyoracle.ora"ITPUB个人空间Y sJ @Ut

i)E a*c0p7Dm&k+e0c:\>oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE "d:\fangys\initmyoracle.ora"ITPUB个人空间2ulP+mO&u
例:修改一个数据实例ITPUB个人空间-ie,T"ig@&X
c:\>oradim -EDIT -SID myoracle -STARTMODE a
l w2Bk-w]_:?0或
3jIi.B{8HO w0c:\>oradim -EDIT -SRVC OracleServicemyoracle -STARTMODE aITPUB个人空间y|:Ob \(d x9i YP
例:删除一个实例
AI0S fl ]'D0c:\>oradim -DELETE -SID myoracle
|S:m#d$p D4} wf$D+p0或ITPUB个人空间(\!fZf#TgX$pu
c:\>oradim -DELETE -SRVC Oracleservicemyoracle
hDOCnB"I+~ H0例:启动服务与实例ITPUB个人空间Nm ]S:pg
c:\>oradim -STARTUP -SID myoracle -STARTTYPE srvc,inst
;M)\cK*S0只启动服务ITPUB个人空间9n;AT8QFZo
c:\>oradim -STARTUP -SID myoracle -STARTTYPE srvcITPUB个人空间{z&f| {*Y1~w?
启动实例:ITPUB个人空间^RO8~&z;E6n
c:\>oradim -STARTUP -SID myoracle -STARTTYPE inst
"G&~9F+p"q&o `6yS0例:关闭服务与实例
j#S+G9EiXZv0c:\>oradim -SHUTDOWN -SID myoracle  
/u&f4AAn)i0c:\>oradim -SHUTDOWN -SID myoracle -SHUTTYPE srvc,inst

5.启动实例并创建数据库ITPUB个人空间+NX1c Pp2d!V
c:\>oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:\fangys\initmyoracle.ora
,nZNl.xt Y#ls E0c:\>set ORACLE_SID=myoracleITPUB个人空间5X/A-F,v1SGO }}
c:\>sqlplus sys/syspass as sysdba
)U!D6{'f(S:GP&^i9e0sql>startup -pfile=d:\fangys\initmyoracle.ora nomountITPUB个人空间 ? c.Cp([
sql>CREATE DATABASE myoracle
t K.zU'Fp+e8bT0logfile group...
nJC&u v(H*T5e0...

6.创建数据字典ITPUB个人空间7^,u? D W
sql>@d:\oracle\product\10.1.0\db_1\rdbms\admin\catalog.sql;ITPUB个人空间H_4s5bX0|
sql>@d:\oracle\product\10.1.0\db_1\rdbms\admin\catproc.sql;ITPUB个人空间'L2w'yZ'xX
sql>@d:\oracle\product\10.1.0\db_1\rdbms\admin\catrep.sql;ITPUB个人空间?/xdB]F#`
sql>@d:\oracle\product\10.1.0\db_1\javavm\install\initjvm.sql;
i8}*uuPm#A A r0sql>@d:\oracle\product\10.1.0\db_1\sqlplus\admin\ppbld.sql;

一、启动数据ITPUB个人空间6M"f*PW5_O I
$sqlplus "sys/pass as sysdba"ITPUB个人空间"S@H \"{+|$X)Oo
sql>startup

二、启动监听器
aF`_.@H0
  数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。监听进程的启动方法为:ITPUB个人空间8Aya#k,LM?
$lsnrctl start
r9L-e^ `,p;v?HU.Gq0在widnows中,可以从服务列表中启动监听器。
q7D;`'_{$Fn0监听里程配置文件为listener.ora,位于目录/home/app/oracle/product/10.1.0/db1/network/admin/。ITPUB个人空间m8w,S?*H
此配置文件分为两部分,一部分为监听程序本身的配置,包括协议,地址,端口号等;另一部分为监听程序所连接的数据库的实例信息,包括:实例名,全局数据库名,oracle主目录等。监听器可以利用oracle net config 向导来配置。ITPUB个人空间\JQP)v-Px
要显示监听器的运行状态:$lsnrctl status;ITPUB个人空间K)usXE+oC{
要停止监听器:$lsnrctl stop。

三、数据库的启动过程ITPUB个人空间%s:ZV,M%T$T
分为三个阶段:
II1L+?2gL7q01. 启动实例,包括以下操作:
*wG9P:Q$@l1}2wq(\v01) 读取参数文件
VW,{YR p {02) 分配SGAITPUB个人空间Ufclcf
3) 启动后台进程ITPUB个人空间'G%n n0v'Of&b+b
2.装载数据库
)He*H[(~+dUe0装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。
"d9EU*w'bv03.打开数据库ITPUB个人空间d1c3C/cZ
此步骤使用数据库可以进行正常的操作的处理。主要是打开控制文件,数据库文件和日志文件。

四、数据库启动参数ITPUB个人空间/^d%XM;AYTk{
1.NOMOUNT:只启动实例,不装载数据库ITPUB个人空间e!e(Y7baz5s
sql>startup nomount
7`dn Y-H G)g02.MOUNT:启动实例,并装载数据,但不打开数据库
t8M9]3Z1{0sql>startup mount
c$RFD!G5]3X;~03.READ ONLY:将数据库置为只读ITPUB个人空间{t*B*^*^'_A
sql>startup mount
;Iw{e:C V0sql>alter database open read onlyITPUB个人空间v E|5L%X I
4.READ WRITE:以可读写方式打开数据,这是默认方式ITPUB个人空间? lx7l,a(f
sql>startup mount
)G!C(M.A x1o0sql>alter database open read write
)hRO7OHgiuJD05.OPEN:打开数据库,这是默认方式ITPUB个人空间1J8X6R0Qw
sql>startup mountITPUB个人空间(fCK I \ae
sql>alter database open;
-g"}a*}@06.RESTRICT:以受限方式打开,只有具有RESTRICTED SESSION权限的用户才可以连接数据库
C-Y#e"R7SH-p0sql>startup restrictITPUB个人空间3L?+sj'\P2T
7.PFILE:启时指定参数文件
SEM{NC5v0sql>startup pfile=/u02/user/mypfile.ora
j(pT(f'eH$eJ08.FORCE:以强制方式启动数据库
)p"H-|2Q*X \D0sql>startup pfile=/u02/user/mypfile.ora open restrict force

五、数据库的关闭ITPUB个人空间S^^6nF4[e5Md#Q
  与启动过程相对应,关闭包括三个过程
&SF } N{(j$[6O"X01).关闭数据库ITPUB个人空间 |vR!m4hX,Q
2).卸载数据库
q F] `E;v03).关闭数据库实例

1.NORMAL关闭方式ITPUB个人空间3Ek5oSadM{
NORMAL关闭方式是正常关闭方式,是默认关闭方式。在这种关机方式下,数据库服务器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。ITPUB个人空间'Gk {]1Q6A/E
SQL>SHUTDOWN NORMALITPUB个人空间 @nqK1E
2.IMMEDIATE关闭方式
4Q-`Vc1l)[8n0使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回退,中断连接,然后关闭数据库。
5kH;KbL+[c"b0SQL>SHUTDOWN IMMEDIATEITPUB个人空间-uy~ZhV
3.ABORT关闭方式ITPUB个人空间ZfiuF5Ea:uj!~
ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭,对事务膛数据完整性不作检查。是最快的关机方式。ITPUB个人空间.?;XDT!K {[
sql>shutdown abort;ITPUB个人空间#Fu o `;M I2V Z5wn
4.TRANSACTIONAL关闭方式
@mOG-L*\,rM0在这种关机方式中,数据库必须等待所有的客户运行的事务结束,提交或回退。ITPUB个人空间y Fh+l*]6J~D
sql>shutdown transactional

 Oracle数据库的连接结构有三种:ITPUB个人空间PB$_Cno s
1)组合用户与服务器结构:在这种连接方式中,客户端与服务器同处一台机器中,对于每一个用户,其库应用程序与服务器程序组合成单个服务器进程
u Cw @gh/D._${7l[Q02)专用服务器(Dedicated)结构:在这种方式中,对于每一个用户,其数据库应用是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码
cX%b,f!|03)多线程服务器(Multithreaded Server)体系结构:在这种方式中,一个或多个客户应用程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一的关系,而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。

专用服务器
(K['fI(F0dedicated.jpgITPUB个人空间 Uz9\1E3o
专用服务器的工作过程:
7J K~N:~ W4fsi01) 客户端通过oracle net向监听器发连接请求
Pl/YQ.{{9pd o(y-f02) 监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此用户创建一个专用服务器进程
!vJ!?$Dtw03)客户直接与该专用服务器进程进行交互,处理SQL,并且服务器在该会话的PGA中建立一个专用SQL区。ITPUB个人空间(^`:P Bt#FO,l
如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora或修改连接描述串。增加关键字“Server=DEDICATED”,如:
@3GXg2H0prod=ITPUB个人空间 s5C~a:{&O1\
       (DESCRIPTION=
.\ z*g'q}7J0         (ADDRESSLIST=ITPUB个人空间$ivD7}-Da
           (ADDRESS=ITPUB个人空间}_Y;FA V2I([sv
             (PROTOCOL=TCP)(HOST=192.168.0.3)(PORT=1521)
&p;k1dU#J4_p5@-?0             (SERVER=DEDICATED)ITPUB个人空间 oz4o.]Wi
           )
w8gJ;LF R+Y0         )ITPUB个人空间t"KXnH9u*V!Ab
         (CONNECT_DATA=(SID=PROD)ITPUB个人空间7u:?&G cy6^.|"T
        )ITPUB个人空间-W9n _5iQ,ya.zQ g
       )ITPUB个人空间5v-A#c'u yj#x$~|$``
还必须修改SQLNET.ORA文件,增加“USE_DEDICATED_SERVER=TRUE”

多线程服务器体系结构
G/Yj dy!wGl0mts.jpgITPUB个人空间\t$y*O.m
专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支 持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立连接的过程,以级与建立专用服务器连 接过程的不同:
OkmX0N:tz4aV01) 客户通过网络与监听器联系
~rF,z,R+b c z02) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客户请求导向相应的调度程序。ITPUB个人空间8}7y3_@B`2} _qL
3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。
~4H%x6g]-}'xmxX04)一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接将操作请求发送给高度程序。ITPUB个人空间1P`tGV#B
5) 调度程序将客户请求放在SGA的请求队列中
.bKG`1u&w#ML i06) 下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。ITPUB个人空间D5s;I:r y8Z%q
7) 共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中
@f;c(H;nNZ#?z08)调度程序从响应队列中读取数据并将结果送组客户


3C0dU`E6P!I X f0  有几个概念在这里作个补充说明:
9Xn.T+Wdy0
1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。ITPUB个人空间Dx4N4[ B+B!K$]
2) 调度程序(dispatcher):在MTS体系结构中,监听器与调度程序联系,调度程序负责调度MTS中的各个共享服务器进程。


0v AVFG%K0 多线程服务器的设置参数有:
5A%F}%z7\].b0MTS_SERVICE:多线程服务器名称,一般为数据库名ITPUB个人空间,E;z}-J,[L
MTS_DISPATCHERS:初始调度器个数
d)z]x:Pt0MTS_MAX_DISPATCHERS:调度器最大个数ITPUB个人空间UmZKF2]
MTS_SERVERS:共享服务器个数
z(U.k2mi;]@0MTS_MAX_SERVERS:最大共享服务器个数ITPUB个人空间 CJ,v!A.Qa%w
多线程服务器的设置是通过对以上各个参数的设置完成的。格式如下:ITPUB个人空间b?)wT.d3Z0Y3yW
MTS_SERVICE=RS
i*RHt|&M)d5?d0MTS_SERVERS=10
/o8M/`A ITPS0MTS_MAX_SERVERS=100ITPUB个人空间1P ~#d|km{'fjF2s
MTS_DISPATCHERS="(PROTOCOL=TCP)(POOL=YES)(MULT=YES)"ITPUB个人空间K d TA*BQ
MTS_DISPATCHERS="(PROTOCOL=IPX)(POOL=YES)(MULT=YES)"ITPUB个人空间:R5Sn`UR5U C
MTS_DISPATCHERS="(PROTOCOL=IPC)(POOL=YES)(MULT=YES)"
'F.dhIua9P4E0MTS_MAX_DISPATCHERS=100


J(c zW3W;I0Bu;N0有关多线程服务器的数据字典如下:
4p6n+[5]?0V$MTSITPUB个人空间/g:OWP)Prv*J
V$DISPATCHERITPUB个人空间qw9ga;Qc3U-y+I
V$SHARED_SERVER
FF2l f5[0V$CIRCULTITPUB个人空间N[oRF CU
各字典的详细说明请参考Oracle文档。

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

  这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。
@K9@1d8lld+g0Oracle实例由内存区域和后台进程组成
px6z%bf$Y0Q+i;| F:Q0Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取)和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进程,允许多个用户同时使用)。
R%IE;d-s9}+wo0在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下面的说明)外,还有其他后台进程,包括:Dnnn, DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参数 PROCESS设定的值:ITPUB个人空间8V,_z+fT_ Xf
sql>show parameter process
Eq\ HHa zw&~0     当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程来为这些客户服务,此进程在widnows下表现为线程。 此进程的主要作用有:对于用户发出的SQL语句进行语法分析,编译,执行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到 SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应用程序。下面的语句用来查询数据库中的用户会话信息。ITPUB个人空间V CH[Gc
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;ITPUB个人空间 {Tf!H)S]%I
结果中:ITPUB个人空间!n2_ET$SO
sid 表示会话ID号,ITPUB个人空间lQa&r]I
ser 表示会话serial#号,serial#与sid组合以唯一表示一个会话,
e4i-Zv``Vg0spid 表示操作系统进程号,
NOf6C(V%F S0schema 表示数据库用户名,ITPUB个人空间\Hq}0D?0v;E0oR[
typ 表示进程类型,use为用户进程,bac为后台进程
dhEt U]UZk"cH0%hit 表示数据缓冲区命中率,
z)F-JL:^%|,[ \%]0cpu 表示使用cpu的时间,ITPUB个人空间:?_m-c@
bchng 表示修改了的数据块的个数。

下面介绍各个后台进程。
#z[K p%b,w,gv@'AA01. DBWR进程
Cga U4a x&FQ$A,lx2E0DBWR(Database Writer)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。ITPUB个人空间9QFE,a;Z YV.S
当数据缓冲区中的一个数据被修改后,被标记为“脏”,DBWR进程负责将“脏”数据写入磁盘。ITPUB个人空间Y RnHQj2l%RL
DBWR采用LRU算法来替换数据缓冲区中的数据。
o |V*`t9W0DBWR的作用包括
vlv,sK*G7_01) 管理数据缓冲区,以便服务器进程总能找到空闲缓冲区ITPUB个人空间-yV1p hq(`c n
2) 将所有修改后的缓冲区中的数据写入数据库文件
~;? ?k&ubF03) 使用LRU算法将最近使用过的块保留在内存中ITPUB个人空间|`-u ~Y s z C
4) 通过延迟写来优化磁盘i/o.ITPUB个人空间+~&p;zc}*H
在下列情况下DBWR要将脏数据写入磁盘数据文件:
fd&e`y(Z01) 当一个服务器进程将缓冲数据块移“脏表”,面该脏表达到一定程度进。(该临界长度由参数DB_BLOCK_WRITE_BATCH决定)
#iz5S)T$@+lfF ^9~02) 当一个服务器进程在LRU表中查找DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空闲的缓冲区
7^2^d6Y9kl b#j03) 出现超时
~sd6dU/TAz04) 检查点发生时ITPUB个人空间&uA~ j+Yu4REP
一个Oracle实例中,允许启动多个DBWR进程,DBWR进程个数由参数DB_WRITE_PROCESSES指定,上限为20,进程名依次自动命名为:DBW0,DBW1,DBW2...DBW19。ITPUB个人空间8\1H \!h/aR@C2_
sql>show parameter processes

2. LGWR进程
^,rnx.Y0LGWR(Log Writer)进程将日志数据从日志缓冲区中写入磁盘日志文件中。ITPUB个人空间_5R#\cXs
关于LGWR进程的工作时机可以看我写的第一篇《一次事务过程》。ITPUB个人空间Jqh"J9q:RYH
LGWR的写盘条件是:ITPUB个人空间e M c}-J}
1) 发生提交,即commit;ITPUB个人空间l7x1L&AA
2) 日志缓冲区达到总数的1/3时;ITPUB个人空间~/?6FuZ9|~
3) 超时;
|l!s&l%F1p$v%n04) DBWR进程需要为检验点清除缓冲区时。ITPUB个人空间}(i0G1M Qs W B'wA
一个Oracle实例只有一个LGWR进程。ITPUB个人空间}J"B(q4l m
LGWR将日志信息同步的写入到日志文件组的多个日志成员中,如果组中的一个成员文件被删除或不可使用,LGWR将日志信息继续写到该组的其他文件中,不影响数据库的运行。

3. SMON进程
:Jw(K.V K!}BJ$Wf0SMON(System Monitor),系统监控进程,在实例启动时执行实例恢复,并负责清理不再使用的临时段。

4. PMON进程ITPUB个人空间2K`s:[g"|E:P[
PMON(Process Monitor),进程监控里程,在服务器进程出现故障时执行进程恢复,负责清理内存内存和释放该进程所使用的资源。

5. ARCH进程
B;s@W)GZ@Wq0ARCH(Archive Process,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质失败时的恢复。ITPUB个人空间R]\!na N8~5g8f:Bp
日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组,日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。
Px z;E%uD0在一个数据库实例中,归档进程最多可以启动10个,进程名依次自动命名为ARC0,ARC1,ARC2...ARC9,设置方法是:在参数文件中增加 参数LOG_ARCHIVE_MAX_PROCESSES。关于如何启用数据库的自动归档,在前面的《物理结构》一篇中已有说明,这里说明一个几个相关的 参数:ITPUB个人空间$a&PC,Ms$H)y2z
1) LOG_ARCHIVE_DEST:用于设置归档日志的文件存储目录ITPUB个人空间"s0PHW3s2a
2) LOG_ARCHIVE_DUBLEX_DEST:用于设置归档日志文件的镜像存储目录,此参数在oracle 8及以上的版本中支持
0M3DF8Xf7j"v03)LOG_ARCHIVE_DEST_n:用于设置更多的镜像目录,其中,1<=n<=10,该参数有以下三个选项:ITPUB个人空间7y Ui_#kE I.x
(1)MANDATORY:表示必须完成此目录的归档,才可以切换。
g%@ Z T1? D6u0(2)REOPEN:归档目录或介质失败后需等多长时间能重新写入日志,默认时间为300秒。ITPUB个人空间;p:_s&q i+D!kS
(3)OPTIONAL:不管是否归档完成都进行切换,这是默认方式
?U4c},g(C-M1a0举例如下:
4q,_,m'b0bWM0LOG_ARCHIVE_DEST_1='LOCATION=/u01/oracle/archive/ITPUB个人空间7q!I%S3j `ry
                       MANDATORYITPUB个人空间$h.Hu,NH+D
                       REOPEN=500'ITPUB个人空间9a,]!R gE
LOG_ARCHIVE_DEST_2='LOCATION=/u02/oracle/archive/ITPUB个人空间 o0{UqWO4@5[R sr
                       OPTIONAL'
C,M6n:}w0eI4ZH0LOG_ARCHIVE_DEST_n只适用于oracle 8i及以上的版本。ITPUB个人空间 q9Y.t8O3K0p\ r3a)[8x
4) LOG_ARCHIVE_DEST_STATE_n:用于对归档日志目录进行失效或生效,该参数与LOG_ARCHIVE_DEST_n一一相对应。如:ITPUB个人空间 L/K tn)c?B
LOG_ARCHIVE_DEST_STATE_1=DEFERITPUB个人空间GR4Qj5xg
LOG_ARCHIVE_DEST_STATE_2=ENABLE
.Nj7R,{q"]-^%t|].p0此参数可以在线设置:
]W(ICr-Y Q0sql> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1=DEFER;ITPUB个人空间9x[H4pE(q6y
此参数只适用于oracle及以上版本。

6. CKPT进程ITPUB个人空间:X#g5k#~jAv1w"t;M
CKPT(CheckPoint,检查点)进程出现时,系统对全部数据库文件及控制文件的文件头的同步号进行修改,以保证数据库的同步
o ~0MyCt0以下两个参数是对CKPT有影响的:
Krbg(Jz5D!g0LOG_CHECKPOINT_TIMEOUT:决定产生一个检验点的时间间隔,单位为秋,默认为1800;
;^[0`xV'Bh$mkK0LOG_CHECKPOINT_INTERVAL:执行一个检验点需要填充的日志文件块的数目,默认为0,表示不起作用。ITPUB个人空间 hE f5vz8i
系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步依据,同时存储在这三个中,在系统改变时,检验点号也会同时改变。
7w8Ua-Oq4D{;s0引起CKPT产生的主要时机有:ITPUB个人空间'aZ_'Gd3M
1)日志切换时
X,d3I\Ey |D02)达到LOG_CHECKPOINT_TIMEOUT指定的间隔时间ITPUB个人空间v9~SU8C;V5x K
3)达到LOG_CHECKPOINT_INTERVAL指定的日志块数ITPUB个人空间$Nr {\V|u
4)数据库关闭
s_ m)Ujb0D05)DBA强制产生ITPUB个人空间V_h|)D
6)表空间OFFLINE时

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

8. LCKn进程
2U c\(P1]'P0LCKn(锁进程)用于Oracle并行服务器环境下,用于多个实例间的封锁,该进程最多可以启动10个。

9. Dnnn进程ITPUB个人空间-F }.s7u w'YB#g"Dii
Dnnn(Despatcher,调度)进程。用于多线程服务器体系结构中。详见下一篇《Oracle连接配置结构》

10. SNP进程ITPUB个人空间J(q d(@4RF,_&cZ3@"A+V
SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自动刷新,并同时通达DBMS_JOB程序包自动运行预定的存储过程,SQL,PL/sql程序等。有两个参数用来控制作业进程的计划:
0lBH#}#~?,@'z01) JOB_QUEUE_PROCESS:用于设置作业进程个数
2?BAf*up$h6a02) JOB_QUEUE_INTERVAL:用于设置作业进程被周期性唤醒的时间间隔

后台进程跟踪信息ITPUB个人空间JW-y*F5im| ka P
所有修改数据库结构的命令会自动被后台进程跟踪记录,跟踪信息由oracle后台进程自动存储,跟踪文件的名称为alter_SID。此文件的存储目录由参数BACKGROUND)DUMP_DEST指定。
!IaZeq%\4Z ?sn0可以用工具命令TKPROF来格式化跟踪文件,如:ITPUB个人空间 i:`t&d*m({8Q w)\
$tkprof oralogfile1.log
O)Fj9?A3p+nY/jBW0除了跟踪后台进程外,还可以启用参数SQL_TRACE对用户的语句进行跟踪。修改参数文件:ITPUB个人空间 sR-\!H]5QUHS
TIMED_STATISTICS=TRUE
-s;Z6r$o(cz0USER_DUMP_DEST=目录名
6J'U Vv$s r2P oF0MAX_DUMP_FILE_SIZE=5MITPUB个人空间8h VN:X:gQ
SQL_TRACE=TRUE
$|ma'i^1B|Fa0或者:
`A3o@:_WJ/Z&d_e|0SQL>ALTER SESSION SET SQL_TRACE=TRUE对当前会话进行SQL跟踪

锁等待问题与KILL SESSION
y4r9Y/i D$VyG#t0R0为了保证数据的一致性,系统提供锁机制。有关锁的概念可以参数《数据库系统概论》一书。要了解当前在等待锁资源的用户
d0j4k7yum"a"E7M0sql>select a.username,a.sid,a,serial#,b.id1 from v$session,v$lock where a.lockwait=b.kaddr;
'et'i+r"d|S2N-fF0要了解锁住其它用户的用户进程
I(K VO _0SQL>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;


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/25472150/viewspace-689151/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/25472150/viewspace-689151/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值