Oracle 10g 进程体系学习总结

    由于Oracel 10g 是一个多进程多线程的数据库,而SQL server是一个单进程多线程的数据库

       Oracel实例主要有3类进程

        1,服务器进程

        2,后台进程

        3,从属进程

 

    服务器进程:分为专有服务器进程和共享服务器进程

    后台进程:

           1,PMON(进程监视器)

              该进程是在出现异常中止后完成操作,还包括监视其他后台进程,如果这些进程崩溃,他来负责重启进程。PMON还会向Oracle TNS 监听器注册当前实例

           2,SMON(系统监视器)

              它完成所有“系统级”的任务:

                  清理临时表空间,合并空闲时间,执行RAC的节点恢复,收缩和“离线”回滚段 

           3,RECO(分布式数据库恢复)

                负责2PC事务处理

           4,CKPT(检查点进程)

                  更新数据库文件的文件首部,以辅助建立真正的检查点进程(dbwn)

           5,DBWn(数据写入器)

                   负责将脏块写入磁盘的后台进程

           6,LGWr(日志写入器)

                   将重做日志的数据写入磁盘

                    1,每3秒中执行一次,2 ,任何事务提交时,3,重做日志缓存区1/3满时,或者包含1M数据: 触发执行

           7,ARCn(归档进程)

              当在线重做日志填满时,将日志文件复制到另一个位置。

    从属进程:

         I/O从属进程和并行查询进程

   详细说明:

     SMON是系统监视器(System Monitor)的缩写。如果Oracle实例失败,则在SGA中的任何没有写到磁盘中的数据都会丢失。有许多情况可能引起Oracle实例失败,例如,操作系统的崩溃就会引起Oracle实例的失败。当实例失败之后,如果重新打开该数据库,则背景进程SMON自动执行实例的复原操作。

  DBWR是数据库书写器(Database Write)的缩写.该服务器进程在缓冲存储区中记录所有的变化和数据,DBWR把来自数据库的缓冲存储区中的脏数据写到数据文件中,以便确保数据库缓冲存储区中有足够的空闲的缓冲存储区。脏数据就是正在使用但是没有写到数据文件中的数据。

  LGWR是日志书写器(Log Write)的缩写。LGWR负责把重做日志缓冲存储区中的数据写入到重做日志文件中。

  CKPT进程是检查点(Checkpoint)的缩写。该进程可以用来同步化数据库的文件,它可以把日志中的文件写入到数据库中。

  PMON是进程监视器(Process Monitor)的缩写。当取消当前的事务,或释放进程占用的锁以及释放其它资源之后,PMON进程清空那些失败的进程。

原文地址:https://www.cnblogs.com/zping/p/1260300.html