sql语句创建oracle数据库名,Oracle中用sql语句创建数据库(2)

专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立连接的过程,以级与建立专用服务器连接过程的不同:

1) 客户通过网络与监听器联系 2) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客户请求导向相应的调度程序。

3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。 4) 一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接将操作请求发送给高度程序。

5) 调度程序将客户请求放在SGA的请求队列中。 6) 下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。 7) 共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中。 8) 调度程序从响应队列中读取数据并将结果送组客户。有几个概念在这里作个补充说明:

1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。

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,DBW1,DBW2...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,ARC1,ARC2...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进程

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值