数据库名、实例名、数据库域名、全局数据库名、服务名.doc_第1页
数据库名、实例名、数据库域名、全局数据库名、服务名.doc_第2页
数据库名、实例名、数据库域名、全局数据库名、服务名.doc_第3页
数据库名、实例名、数据库域名、全局数据库名、服务名.doc_第4页
数据库名、实例名、数据库域名、全局数据库名、服务名.doc_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据库名、实例名、数据库域名、全局数据库名、服务名 ,这是几个令很多初学者容易混淆的概念。相信很多初学者都与我一样被标题上这些个概念搞得一头雾水。我们现在就来把它们弄个明白。 一、数据库名什么是数据库名?数据库名就是一个数据库的标识,就像人的身份证号一样。他用参数DB_NAME表示,如果一台机器上装了多全数据库,那么每一个数据库都有一个数据库名。在数据库安装或创建完成之后,参数DB_NAME被写入参数文件之中。格式如下:DB_NAME=myorcl.在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。因为,数据库名还被写入控制文件中,控制文件是以 二进制型式存储的,用户无法修改控制文件的内容。假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。但是在Oracle启动时,由于参数文 件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。数据库名的作用数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、备份与恢复数据库时都需要使用到的。有很多Oracle安装文件目录是与数据库名相关的,如:winnt: d:oracleproduct10.1.0oradataDB_NAME.Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/.pfile:winnt: d:oracleproduct10.1.0adminDB_NAMEpfileini.oraUnix: /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并行服务器架构(即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:协议适配器错误”。数据库实例名与网络连接数据库实例名除了与操作系统交互外,还用于网络连接的oracle服务器标识。当你配置oracle主机连接串的时候,就需要指定实例名。当然8i以后版本的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。三、数据库域名什么是数据库域名?在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于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网络组件,数据库与客户端的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名创建Oracle数据库(以Oracle10g为例)有两种创建数据库的方式,一种是以命令行脚本方式,即手动方式创建;另一种是利用Oracle提供的数据库配置向导来创建。本篇主要介绍在Unix和Windows下以命令行脚本方式创建Oracle数据库。 一个完整的数据库系统,应包括一个物理结构、一个逻辑结构、一个内存结构和一个进程结构,如果要创建一个新的数据库,则这些结构都必须完整的建立起来。一、在Unix下创建数据库1.确定数据库名、数据库实例名和服务名关于数据库名、数据库实例名和服务名,我之前有专门用一篇来详细介绍。这里就不再说明了。2.创建参数文件 参数文件很确定了数据库的总体结构。Oracle10g有两种参数文件,一个是文本参数文件,一种是服务器参数文件。在创建数据库时先创建文本参数文件, 在数据库创建后,可以由文件参数文件创建服务器参数文件。文本参数文件的取名方式为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.ora1)参数文件的介绍参数文件决定着数据库的总体结构,用于设置数据库的近260个系统参数。下面分类别说明一下各参数的作用,关于参数的详细使用说明请参考Oracle官方参考文档。a.数据库标识类参数DB_NAME: 数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制文件DB_DOMAIN: 数据库域名,用于区别同名数据库。数据库名与域名一起构成了全局数据库名INSTANCE_NAME: 数据库实例名,可以与数据库相同SERVICE_NAMES: 数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名b.日志管理类参数LOG_ARCHIVE_START: 是否启动自动归档进程ARCHLOG_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:最大进程数,包括后台进程与服务器进程IFILE:另一个参数文件的名字DB_RECOVERY_FILE_DEST:自动数据库备份目录DB_RECOVERY_FILE_SIZE:数据库备份文件大小2)参数文件样式db_name=myoracleinstance_name=myoracledb_domain=service_names=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=8192user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udumpbackground_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdumpcore_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdumpdb_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_areadb_recovery_file_size=100G.3.设置操作系统参数$ORACLE_SID=myoracle$export ORACLE_SID4.启动实例并创建数据库在创建数据库之前,首先要以新的数据库参数启动数据库实例,因为这时数据库的控制文件还没有产生,不能MOUNT或OPEN数据库。启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。$sqlplus sys/pass as sysdbasqlstartup nomount如果参数文件不在规定的目录中,可以在启动实例时指定参数文件:sqlstartup pfile=/export/home/user/initmyoracle.init nomount在实例启动后就可以使用CREATE DATABASE命令创建数据。其详细语法请参考Oracle官方SQL参考文档。这里以实例来介绍:sqlCREATE DATABASE myoracle MAXINSTANCE 1 MAXLOGHISTORY 216 MAXLOGFILES 50 MAXLOGMEMBERS 5DATAFILE /home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf SIZE 500mAUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDLOGFILE 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 200mAUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDDEFAULT TEMPORARY TALESPACE temp TEMPFILE/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf size 325mAUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITEDDEFAULT TABLESPACE users DATAFILE/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf size 1000mCHARACTER SET ZHS16GBK;这里说明一下CREATE DATABASE语句的各个关键字的含义: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/catalog2)加载PL/SQL程序包sql/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catproc3)加载数据复制支持软件包sql/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep4)加载Java程序包sql/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvm5)加载系统环境文件sqlconnect system/passsql/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld二、在Windows下创建数据库Oracle实例在Windows下表现为操作系统服务。在windows下,使用命令行方式创建数据的方法有所不同,差别在于在Windows下,需要先创建数据库服务和实例。1.确定数据库名、数据库实例名和服务名并创建目录(DBCA创建的脚本不包含建立目录命令,须自己创建)建立目录命令(下面以 db_name=eygle为例):mkdir D:oracleora90cfgtoollogsdbcaeyglemkdir D:oracleora90databasemkdir d:oracleadmineygleadumpmkdir d:oracleadmineyglebdumpmkdir d:oracleadmineyglecdumpmkdir d:oracleadmineygledpdumpmkdir d:oracleadmineyglepfilemkdir d:oracleadmineygleudumpmkdir d:oracleflash_recovery_areamkdir d:oracleoradatamkdir d:oracleoradataeygle2.创建参数文件在Windows下的参数文件名称及路径如下:d:oracleproduct10.1.0adminDB_NAMEpfileinit.ora(oracle10g)d:orantdatabaseiniORACLE_SID.ora(oracle7,oracle8)参数据文件内容与前述一致。这里不再说明。3.选择数据库实例设置环境变量ORACLE_SIDc: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:fangysinitmyoracle.ora或c:oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE d:fangysinitmyoracle.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,inst5.启动实例并创建数据库c:oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:fangysinitmyoracle.orac:set ORACLE_SID=myoraclec:sqlplus sys/syspass as sysdbasqlstartup -pfile=d:fangysinitmyoracle.ora nomountsqlCREATE DATABASE myoraclelogfile group.6.创建数据字典sqld:oracleproduct10.1.0db_1rdbmsadmincatalog.sql;sqld:oracleproduct10.1.0db_1rdbmsadmincatproc.sql;sqld:oracleproduct10.1.0db_1rdbmsadmincatrep.sql;sqld:oracleproduct10.1.0db_1javavminstallinitjvm.sql;sqld:oracleproduct10.1.0db_1sqlplusadminppbld.sql;一、启动数据$sqlplus sys/pass as sysdbasqlstartup二、启动监听器数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。监听进程的启动方法为:$lsnrctl start在widnows中,可以从服务列表中启动监听器。监听里程配置文件为listener.ora,位于目录/home/app/oracle/product/10.1.0/db1/network/admin/。此配置文件分为两部分,一部分为监听程序本身的配置,包括协议,地址,端口号等;另一部分为监听程序所连接的数据库的实例信息,包括:实例名,全局数据库名,oracle主目录等。监听器可以利用oracle net config 向导来配置。要显示监听器的运行状态:$lsnrctl status;要停止监听器:$lsnrctl stop。三、数据库的启动过程分为三个阶段:1. 启动实例,包括以下操作:1) 读取参数文件2) 分配SGA3) 启动后台进程装载数据库装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。打开数据库此步骤使用数据库可以进行正常的操作的处理。主要是打开控制文件,数据库文件和日志文件。四、数据库启动参数1.NOMOUNT:只启动实例,不装载数据库 sqlstartup nomount2.MOUNT:启动实例,并装载数据,但不打开数据库sqlstartup mount3.READ ONLY:将数据库置为只读sqlstartup mountsqlalter database open read only4.READ WRITE:以可读写方式打开数据,这是默认方式sqlstartup mountsqlalter database open read write5.OPEN:打开数据库,这是默认方式sqlstartup mountsqlalter database open;6.RESTRICT:以受限方式打开,只有具有RESTRICTED SESSION权限的用户才可以连接数据库sqlstartup restrict7.PFILE:启时指定参数文件sqlstartup pfile=/u02/user/mypfile.ora8.FORCE:以强制方式启动数据库sqlstartup pfile=/u02/user/mypfile.ora open restrict force五、数据库的关闭与启动过程相对应,关闭包括三个过程)关闭数据库)卸载数据库)关闭数据库实例NORMAL关闭方式NORMAL关闭方式是正常关闭方式,是默认关闭方式。在这种关机方式下,数据库服务器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。SQLSHUTDOWN NORMALIMMEDIATE关闭方式使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回退,中断连接,然后关闭数据库。SQLSHUTDOWN IMMEDIATEABORT关闭方式ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭,对事务膛数据完整性不作检查。是最快的关机方式。sqlshutdown abort;TRANSACTIONAL关闭方式在这种关机方式中,数据库必须等待所有的客户运行的事务结束,提交或回退。sqlshutdown transactionalOracle数据库的连接结构有三种:1) 组合用户与服务器结构:在这种连接方式中,客户端与服务器同处一台机器中,对于每一个用户,其库应用程序与服务器程序组合成单个服务器进程。2) 专用服务器(Dedicated Server)结构:在这种方式中,对于每一个用户,其数据库应用是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码。3) 多线程服务器(Multithreaded Server)体系结构:在这种方式中,一个或多个客户应用程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一的关系,而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。专用服务器专用服务器的工作过程:1) 客户端通过oraclenet向监听器发连接请求2) 监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此用户创建一个专用服务器进程3) 客户直接与该专用服务器进程进行交互,处理,并且服务器在该会话的PGA中建立一个专用SQL区。如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora或修改连接描述串。增加关键字“Server=DEDICATED”,如:prod= (DESCRIPTION= (ADDRESSLIST= (ADDRESS= (PROTOCOL=TCP)(HOST=)(PORT=1521) (SERVER=DEDICATED) ) ) (CONNECT_DATA=(SID=PROD) ) ) 还必须修改SQLNET.ORA文件,增加“USE_DEDICATED_SERVER=TRUE” 多线程服务器体系结构专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支 持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立连接的过程,以级与建立专用服务器连 接过程的不同:1) 客户通过网络与监听器联系2) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客户请求导向相应的调度程序。3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。4) 一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接将操作请求发送给高度程序。5) 调度程序将客户请求放在的请求队列中。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=RSMTS_SERVERS=10MTS_MAX_SERVERS=100MTS_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$MTSV$DISPATCHERV$SHARED_SERVERV$CIRCULT各字典的详细说明请参考Oracle文档。第八篇 再述oracle数据库体系结构 之四:Oracle实例的进程结构这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。Oracle实例由内存区域和后台进程组成。Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取)和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进程,允许多个用户同时使用)。在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下面的说明)外,还有其他后台进程,包 括:Dnnn,DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参数 PROCESS设定的值:sqlshow parameter process 当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程来为这些客户服务,此进程在widnows下表现为线程。 此进程的主要作用有:对于用户发出的SQL语句进行语法分析,编译,执行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到 SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应用程序。下面的语句用来查询数据库中的用户会话信息。sqlselect 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表示会话号,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。sqlshow 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. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论