2022年数据库核心进程资料 .pdf

上传人:Q****o 文档编号:28418229 上传时间:2022-07-28 格式:PDF 页数:6 大小:83.24KB
返回 下载 相关 举报
2022年数据库核心进程资料 .pdf_第1页
第1页 / 共6页
2022年数据库核心进程资料 .pdf_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《2022年数据库核心进程资料 .pdf》由会员分享,可在线阅读,更多相关《2022年数据库核心进程资料 .pdf(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、ARC0 ,需要访问脱机存储设备和控制文件;以及 CKPT ,需要访问数据文件和控制文件。数据库写入进程( DBWn )数据库写入进程 database writer process (DBWn),将 buffer中的内容写入数据文件中。 DBWn 进程负责将在 buffer cache 中的那些修改的 buffer ,也就是脏数据写入磁盘中。对于大多数系统来说, 1 个进程 (DBW0) 就足够了,但也可以通过设置初始化参数DB_WRITER_PROCESSES, 增加数据库写入进程, 编号从 DBW0-DBW9以及 DBWa-DBWj,最多可以 20 个进程。但是前提是必须有足够多的CPU

2、 供这些进程使用,在一个单 CPU 的系统中,额外地配置该进程并不能提高性能,所以需要根据 CPU 及处理器的个数决定如何设置该参数。当一个buffer在数据库的buffer cache中被修改了,就会被标记为脏数据(dirty)。 Buffer cache 的冷端 (cold buffer)是指根据 LRU(least recently used)算法选择出的, 最近最少使用的buffer 。DBWn 进程将冷端的、 脏的 buffer写入磁盘,这样用户进程就可以查找冷端、干净的buffer用于将新的数据块读入cache 中。当一个buffer被用户进程修改 ( 弄脏),此 buffer就不

3、再是free buffer ,不能用于新数据的写入。如果free buffer数量过少,用户进程就会找不到足够的空间用于数据写入。而DBWn 进程有效地管理了buffer cache,让用户进程总是能够获得free buffer。DBWn 进程总是将冷端、脏buffer写入磁盘, DBWn 在改善查找 free buffer性能的同时,也另最近频繁使用的buffer保留在内存中。例如,储存那些频繁访问且较小的表或索引的数据块,可以keep 在 cache 中,没必要反复地从磁盘中读取。由于LRU算法将访问频率高的数据块保留在buffer cache中,所以一个buffer被写入磁盘中,该buf

4、fer所包含的数据被马上访问的概率较小。满足以下条件时, DBWn 进程会将脏数据缓冲区 (dirty buffers)写入磁盘: 当服务器进程扫描了一定数量的buffer之后,没有找到干净的可用的buffer ,它通知 DBWn 写入。DBWn 将 buffer写入磁盘的操作是异步的,因为在DBWn 工作的同时还有其他进程在执行。DBWn 周期性地写 buffer ,从而使得 checkpoint前移,checkpoint是当一个实例需要实例恢复时,应用重做日志的起始位置。这个位置是由buffer中最早的脏数据缓冲区 (dirty buffers)决定的。无论那种情况, DBWn 进程都是批

5、量 ( 一次多数据块 ) 地写入以提高性能。一次批量写入的数据块的数量随操作系统的不同而改变,没有固定值。日志写入进程( LGWR)日志写入进程log writer process (LGWR)负责管理日志缓冲区,将名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 6 页 - - - - - - - - - 日志缓冲区写入磁盘上的日志文件。LGWR 将从上次之后才复制到buffer中的重做条目写入磁盘。日 志 缓 冲 区 (redo log buffer)是 一 个 环 形

6、 的 缓 冲 区 (circular buffer)。当 LGWR 进程将日志缓冲区的重做条目写入日志文件,服务器进程同时也将新的条目复制到日志缓冲区覆盖那些已经写入磁盘的条目。LGWR 通常需要保证足够快地写入,即使在频繁访问redo log时也要确保缓冲区有足够的空间用于写入新的条目。 LGWR将一部分连续的buffer写入磁盘。 LGWR 写入的内容有:一个用户进程提交事务的提交记录。Redo log buffer,以下 3 个条件,满足其中一个就写入。每三秒写入一次。当日志缓冲区使用了三分之一。当 DBWn 进程向磁盘写入脏缓冲区,但需要写入的日志还没有写入。注意:在 DBWn 进程向

7、磁盘写入脏数据之前,所有与修改数据相关的重做记录都必须被写入磁盘,这就是先写日志原则(write-ahead protocol)。如果 DBWn 发现有一些重做记录没有写入磁盘, 会通知 LGWR 将它们写入, 并等待将 LGWR 进程将重做日志缓冲区内的相关数据写入磁盘后,才能将数据缓冲区写入磁盘。LGWR 同步地向一个日志组的多个镜像成员写入。如果其中的一个成员文件损坏了, LGWR 继续向其他成员写入, 并将错误记录到 LGWR 进程的 trace 文件和 alert log 中。如果一个日志组的所有成员文件都损坏了,或者日志组由于未归档而暂时不可用,那么 LGWR 就无法继续工作了。当

8、用户执行了一句commit 时,LGWR 将提交记录放进日志缓冲区,并且将它与事务的重做条目一起立即写入磁盘。而相关的被修改的数据块要等待更高效的时机时才写入磁盘。这被成为快速提交(fast commit) 机制。一个事务的提交记录及相关的重做条目将通过一个原子性(atomic) 的写操作记录到磁盘上,这个单一事件决定了事务是否被成功地提交。尽管此时被修改的数据缓冲区还没有写入磁盘, Oracle 已经能够向用户返回事务提交成功的信息。注意:有时,如果重做日志缓冲区内空间不足,LGWR 进程会在事务提交前就将重做日志条目写入磁盘。这样的重做日志条目只有在相关事务提交后才能永久地存储。当一个用户

9、提交一个事务时,这个事务就被赋予了一个系统改变号system change number (SCN),Oracle 将在事务的重做条目中记录此编号。SCN是被记录在 redo log中的,所以恢复 (recovery)操作可以在 RAC 、分布式数据上同步地进行。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 6 页 - - - - - - - - - 在数据修改操作较频繁时, LGWR 进程能够采取 批量提交 (group commits) 技术向重做日志文件写入数据。

10、例如,当一个用户提交了一个事务后,LGWR 进程会将此事务的重做条目( redo entry )写入磁盘,与此同时系统中的其他用户也可能在执行 COMMIT 语句。但是 LGWR 进程需要在之前的写入操作完成后,才能为后续的提交事务写入重做信息。 当第一个事务的重做条目被写入磁盘后,在此期间等待提交的事物的重做条目可以被一起写入磁盘,这比分别写入每个事务的重做条目所需的 I/O 操作要少。Oracle 通过这种办法减少了磁盘 I/O 并提升了 LGWR 进程的性能。如果系统中的提交频率一直很高,那么 LGWR 进程每次从重做日志缓冲区向磁盘的写入数据中都包含多个提交事务的信息。检查点进程( C

11、KPT )当一个 checkpoint发生时,Oracle 必须更新所有数据文件的文件头,记录这个 checkpoint的详细信息。这个动作是由CKPT进程完成的,但是CKPT进程并不将数据块写入磁盘,写入的动作总是由DBWn 进程完成的。由企业管理器(Enterprise Manager)的 System_Statistics 监视器显示的 DBWR checkpoints 统计信息显示了系统中需要完成的检查点操作。系统监控进程( SMON)实例启动时如有需要,系统监控进程(system monitor process ,SMON)将负责进行恢复( recovery )工作。此外, SMON

12、 还负责清除系统中不再使用的临时段(temporary segment ) ,以及为数据字典管理的表空间(dictionary managed tablespace )合并相邻的可用数据扩展(extent ) 。在实例恢复过程中,如果由于文件读取错误或所需文件处于脱机状态而导致某些异常终止的事务未被恢复,SMON 将在表空间或文件恢复联机状态后再次恢复这些事务。SMON 进程定期检查自己是否被需要,系统内的其他进程发觉需要时也能够调用SMON 进程。在 RAC 环境中,一个实例的 SMON 进程能够为出错的 CPU 或 实例进行实例恢复( instance recovery) 。进程监控进程(

13、 PMON)当一个用户进程( user process )失败后,进程监控进程(process monitor,PMON) 将对其进行恢复。PMON 进程负责清理数据缓冲区 (database buffer cache)并释放用户进程使用的资源。 例如,它可以重置活动事务表 (active transaction table) 的状态,释放锁,将某个进程ID 从活动进程列表中移除。PMON 进程会周期性地对调度器(dispatcher)和服务进程( server process)进行检查,重新启动停止运行的进程 (不包括 Oracle 有意停止的进程)。 PMON 进程还负责将实例和调度器进程

14、的信息注册到网络监听器(network listener) 。同 SMON 一样,PMON 进程定期检查自己是否被需要,系统内的其他进程发觉需要时也能够调用 PMON 进程。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 6 页 - - - - - - - - - 恢复进程( RECO )恢复进程 recoverer process (RECO)用于分布式数据库结构,自动解决分布式事务的错误。一个节点的RECO 进程会自动地连接到一个有疑问的分布式事务的相关其他数据库。当

15、RECO 重新连接到相关的数据库服务时,它会自动地解决有疑问的事务。并从相关数据库的活动事务表(pending transaction table )中移除和此事务有关的数据。如果 RECO 进程无法连接到远程服务,RECO 会在一定时间间隔后尝试再次连接。但是每次尝试连接的时间间隔会以指数级的方式增长。只有实例允许分布式事务时才会启动 RECO 进程。实例中不会限制并发的分布式事务的数量。作业队列进程( Job Queue Processes )一般由两类进程组成:作业队列协调进程coordinator job queue process (CJQn),起到对作业队列的监控作用。执行作业的队

16、列进程job queue processes (Jnnn),由 CJQn完成调度产生。作业队列进程用于批处理,执行用户job ,可以将它们看做一个调度服务,用于调度 Oracle 实例上如 PL/SQL语句或存储过程的job 。提供开始的时间和调度的时间间隔,作业队列进程可以根据这个配置,自动地周期性地执行。作业队列进程可以被动态地管理。可以允许作业队列客户端根据需要使用多个作业队列进程,当一个作业队列进程进入空闲状态(idle )后,其使用的资源将被释放。动态的作业队列进程可以按指定的时间间隔运行大量的作业。用户的作业是由 CJQ 进程交给作业队列进程执行的。具体步骤如下:1. 名为 CJQ

17、0 的协调进程( coordinator process)定期地从系统JOB$ 表中选择需要运行的 job 。被选出的作业将按照时间排序。2. CJQ0 进程动态地产生job队列的slave进程来运行这些job ,编号从J000-J999。3. 作业队列进程执行一个由 CJQ 进程选出的作业。每个进程每次只能执行一个job 。4. 当一个工作队列进程执行完一个作业后,就能够接受下一个作业。如果此时系统中已经没有需要被调度的作业了,此进程将进入休眠状态(sleep state) ;此进程还会定期地苏醒(wake up)等待分配其他作业。如果在预设的时间内没有新的作业,此进程将终止。初始化参数JO

18、B_QUEUE_PROCESSES表示实例中可以并行执行的最大作业队列进程数。但是,客户端不应该假设所有的作业队列进程都用于执行job 。注意:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 6 页 - - - - - - - - - 如果初始化参数 JOB_QUEUE_PROCESSES被设置为 0 ,协调进程 (CJQ ) 将不会被启动。归档进程( ARCn )归档进程( archiver process ,ARCn )在发生日志切换( log switch )时将重

19、做日志文件复制到指定的存储设备中。只有当数据库运行在ARCHIVELOG模式下,且自动归档功能被开启时,系统才会启动ARCn 进程。一 个 Oracle 实 例 中 最 多 可 以 运 行 10 个 ARCn 进 程(ARC0 到 ARC9 ) 。如果当前的 ARCn 进程还不能满足工作负载的需要,LGWR 进程将启动新的 ARCn 进程。 Alert log会记录 LGWR 启动 ARCn 进程。如果预计系统存在繁重的归档任务,例如将进行大批量数据装载,可以通过设置初始化参数LOG_ARCHIVE_MAX_PROCESSES来指定多个归档进程, 通过ALTER SYSTEM 语句可以动态地修

20、改该参数,增加或减少归档进程的数量。然而,通常不需要去改变该参数,该参数默认值为1,因为当系统负载增大时,LGWR进程会自动地启动新的ARCn 进程。队列监控进程( QMNn )队列监控进程是一个可选择的进程,它提供Oracle 工作流高级队列,用于监控信息队列。可以配置最多10 个监控进程。这些进程类似作业队列进程与其他 Oracle 后台进程的区别在于,这两类进程出错不会导致整个实例出错。调度进程( Dnnn )调度进程 Dispatcher (Dnnn )是一个可选的Oracle 后台进程,只存在于共享服务器环境中。内存管理进程( MMAN)内存管理进程 Memory Manager(M

21、MAN) 是一个 SGA 后台进程。 10g 新特性,自动共享内存管理Automatic Shared Memory Management(ASMM)启用时,会有这个新的后台进程。 MMAN 服务像是 SGA 内存的经纪人 (SGA Memory Broker)一样,协调内存各组成部分的大小。SGA Memory Broker很清楚内存各组成部分的大小,和有待调整的操作。恢复写入进程(RVWR)Flashback Database 是 Oracle10g 的新增功能,在启动Flashback Database 之后,它定期将已发生变化的块写入闪回日志的日志文件中。这些日志不是由传统的 Log

22、Writer (LGWR) 过程写入,而是由一种称作Recovery Writer (RVWR) 的新过程写入。这是 Oracle10g 的新增进程。闪回数据库是指将数据库返回到一个早前的数据库状态,闪回数据库特性提供了一种快速的方法,将数据库迅速地返回到早前的某个时间点,它不同于传统的基于时间的恢复。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 6 页 - - - - - - - - - 数据库闪回只能从以下错误中恢复:由于逻辑错误导致的。由于用户错误导致的。不能从介

23、质错误中通过闪回特性恢复数据库。闪回数据库所需的时间是与被改变的数据成正比的,而不是数据库的大小。注意,一旦 resetlogs之后,将不能再 flashback至 resetlogs之前的时间点。内存管理进程(MMON)内存管理进程 memory monitor (MMON)是 10g 的新进程,它联合AWR 新特性负责执行多种和可管理性相关(manageability-related)的后台任务,例如:当某个测量值( metrics )超过了预设的限定值( threshold value )后提交警告创建新的 MMON 隶属进程( MMON slave process)来进行快照( sna

24、pshot )捕获最近修改过的 SQL 对象的统计信息它的 slave 进程是 M000 。其他后台进程Oracle 数据库中还可能运行其他后台进程。包括:Memory Monitor Light (MMNL)进程负责执行轻量级的且频率较高的和可管理性相关的后台任务, 例如捕获会话历史信息, 测量值计算等。它与 AWR 一起起作用,将需要的 buffer统计信息写入磁盘。MMAN 进程负责执行数据库系统的内部任务。在使用了自动存储管理(Automatic Storage Management )的实例中, RBAL 进程负责协调磁盘组间的负载平衡工作。她可以使多个实例同时访问一个 ASM 磁盘

25、(global open) 。最终由 ORBn 进程实际执行数据扩展的负载均衡。实例中可以运行多个 ORBn 进程,分别为 ORB0 ,ORB1 ,以此类推。当数据库实例使用 ASM 磁盘组时,还要启动 OSMB 进程。此进程负责和 ASM 实例(Automatic Storage Management instance)通信。LMS (Global Cache Service)进程,在 RAC环境中存在,该进程管理资源,并提供实例资源交互控制。Change Tracking Writer (CTWR)进程,是 10g 中的新进程,用于对最近的改变的块进行跟踪,让RMAN 可以更快地进行增量备份。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 6 页 - - - - - - - - -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 技术总结

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁