sql语句创建oracle数据库名,Oracle中⽤sql语句创建数据库
(2)
专⽤服务器结构中,⼀个服务器进程只为⼀个客户服务。这样的话,如果有⼀千个客户,就需要有⼀千个对应的服务器进程,就会耗费⼤量的系统资源。为了⽀持对于可伸缩性的需求,在oracle7中引⼊了多线程服务器(MTS,也称为共享服务器)。下⾯说明共享服务器建⽴连接的过程,以级与建⽴专⽤服务器连接过程的不同:
1) 客户通过⽹络与联系 2) 检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。将客户请求导向相应的调度程序。
3) 通过使客户与调度程序了解对⽅的⽹络地址,从⾯完成了双⽅的介绍。 4) ⼀旦客户与调度程序知道如何到对⽅,它们就直接通信,不要需要。客户直接将操作请求发送给⾼度程序。
5) 调度程序将客户请求放在SGA的请求队列中。 6) 下⼀个可⽤的共享服务器进程从请求队列中读取请求,进⾏相应的⼯作。 7) 共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中。 8) 调度程序从响应队列中读取数据并将结果送组客户。有⼏个概念在这⾥作个补充说明:
1) (Listener):为⼀个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。不是Or
acle实例的⼀部分,它的作⽤是将连接的请求导向相应的实例。
2) 调度程序(dispatcher):在MTS体系结构中,与调度程序联系,调度程序负责调度MTS中的各个共享服务器进程。多线程服务器的设置参数有:
MTS_SERVICE:多线程服务器名称,⼀般为数据库名
MTS_DISPATCHERS:初始调度器个数
MTS_MAX_DISPATCHERS:调度器最⼤个数
MTS_SERVERS:共享服务器个数
MTS_MAX_SERVERS:最⼤共享服务器个数
多线程服务器的设置是通过对以上各个参数的设置完成的。格式如下:
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有关多线程服务器的数据字典如下:
V$MTS V$DISPATCHER V$SHARED_SERVER V$CIRCULT 各字典的详细说明请参考Oracle⽂档。第⼋篇
再述oracle数据库体系结构
之四:Oracle实例的进程结构这⾥所讲的⾥程是指Unix系统中的进程,在Windows中,Oracle是⼀个操作系统服务。
Oracle实例由内存区域和后台进程组成。
Oracle实例分为单进程实例(⼀个进程执⾏全部的Oracle代码,只允许单个⽤户存取)和多进程实例(由多个进程执⾏Oracle代码的不同部分,对于每⼀个连接的⽤户都有⼀个进程,允许多个⽤户同时使⽤)。
在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下⾯的说明)外,还有其他后台进程,包括:Dnnn,DBWR,
LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参数
PROCESS设定的值:
sql>show parameter process
当Oracle客户端应⽤程序与Oracle实例连接的时候,Oracle会产⽣⼀个服务器进程来为这些客户服务,此进程在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表⽰数据库⽤户名,
typ 表⽰进程类型,use为⽤户进程,bac为后台进程
%hit 表⽰数据缓冲区命中率, cpu 表⽰使⽤cpu的时间,
bchng表⽰修改了的数据块的个数。下⾯介绍各个后台进程。
1. DBWR进程
DBWR(Database Writer)进程将缓冲区中的数据写⼊数据⽂件,负责数据缓冲区的管理。
当数据缓冲区中的⼀个数据被修改后,被标记为“脏”,DBWR进程负责将“脏”数据写⼊磁盘。
DBWR采⽤LRU算法来替换数据缓冲区中的数据。
DBWR的作⽤包括:
1)管理数据缓冲区,以便服务器进程总能到空闲缓冲区
2)将所有修改后的缓冲区中的数据写⼊数据库⽂件
3)使⽤LRU算法将最近使⽤过的块保留在内存中
4)通过延迟写来优化磁盘i/o. 在下列情况下DBWR要将脏数据写⼊磁盘数据⽂件:
1)当⼀个服务器进程将缓冲数据块移“脏表”,⾯该脏表达到⼀定程度进。(该临界长度由参数DB_BLOCK
_WRITE_BATCH决定) 2)当⼀个服务器进程在LRU表中查DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空闲的缓冲区
3)出现超时
4)检查点发⽣时
在⼀个Oracle实例中,允许启动多个DBWR进程,DBWR进程个数由参数DB_WRITE_PROCESSES指定,上限为20,进程名依次⾃动命名为:DBW0,DBW19。
sql>show parameter
processes2. 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),进程监控⾥程,在服务器进程出现故障时执⾏进程恢复,负责清理内存内存和释放该进程所使⽤的资源。5. ARCH进程
ARCH(Archive Process,归档进程)在⽇志存满时将⽇志信息写到磁盘或磁带,⽤于介质失败时的恢复。
⽇志信息⾸先产⽣于⽇志缓冲区,再由⽇志写⼊进程LGWR将⽇志数据写⼊⽇志⽂件组,⽇志切换时,由归档进程ARCH将⽇志数据从⽇志⽂件组中写⼊归档⽇志中。
在⼀个数据库实例中,归档进程最多可以启动10个,进程名依次⾃动命名为ARC0,ARC9,
设置⽅法是:在参数⽂件中增加参数LOG_ARCHIVE_MAX_PROCESSES。关于如何启⽤数据库的⾃动归档,在前⾯的《物理结构》⼀篇中已有说明,这⾥说明⼀个⼏个相关的参数:
1) LOG_ARCHIVE_DEST:⽤于设置归档⽇志的⽂件存储⽬录
2) LOG_ARCHIVE_DUBLEX_DEST:⽤于设置归档⽇志⽂件的镜像存储⽬录,此参数在oracle 8及以上的版本中⽀持
3) LOG_ARCHIVE_DEST_n:⽤于设置更多的镜像⽬录,其中,1 ALTER SYSTEM SET
LOG_ARCHIVE_DEST_STATE_1=DEFER; 此参数只适⽤于oracle 10g及以上版本。6. CKPT进程
如何连接oracle数据库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并⾏服务器环境下,⽤于多个实例间的封锁,该进程最多可以启动10个。9. Dnnn进程
Dnnn(Despatcher,调度)进程。⽤于多线程服务器体系结构中。详见下⼀篇《Oracle连接配置结构》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;

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