首頁 資料庫 mysql教程 Oracle background processes后台进程

Oracle background processes后台进程

Jun 07, 2016 pm 03:53 PM

按照使用对象分为客户端进程(client)ORACLE进程,ORACLE进程有分为后台进程(background)、服务进程(server)和从进程(slav

Oracle进程类型:
对于数据库的进程,数据库实例包含或与之交互。
按照使用对象分为客户端进程(client)ORACLE进程,ORACLE进程有分为后台进程(background)、服务进程(server)和从进程(slave)。server进程执行基于client进程的请求。
例如:server进程解析SQL查询,将这些查询语句存放于shared pool中,对每个查询创建并执行查询计划。并且从buffer cache或磁盘中读取数据。
 
进程结构依赖于操作系统和ORACLE数据库可选模式。
服务(server)进程可以分为专享(dedicated)和共享(shared)服务
专享模式下的进程结构

Oracle background processes后台进程


 
共享模式下的进程结构

Oracle background processes后台进程

通过V$PROCESS视图查看一下进程信息:
col addr for a16
COL SPID FORMAT a8    --系统进程
COL STID FORMAT a8    --系统线程
col usrname for a20
col program for a25
select addr,pid,spid,stid,usrname,program from v$process order by stid;


客户端(client)进程:
ps -ef | grep -e sample -e sqlplus | grep -v grep

在客户端和服务端用以下命令查看的结果是不同的,客户端仅显示sqlplus进程。服务端显示为非本地连接。
 
关于会话连接:
使用ORACLE的autotrace收集执行语句统计信息时,会自动创建一个场景
SQL> select sid,serial#,paddr from v$session where username=user;
      SID    SERIAL# PADDR
---------- ---------- ----------------
        96          3 00000001F051C858
SQL> set autotrace on statistics;      ---跟踪SQL语句执行计划额外重建了一个场景
SQL> select sid,serial#,paddr from v$session where username=user;
      SID    SERIAL# PADDR
---------- ---------- ----------------
        96          3 00000001F051C858
        98          5 00000001F051C858
 
SQL> SELECT PROGRAM FROM V$PROCESS WHERE ADDR = hextoraw('00000001F051C858');
PROGRAM
---------------------------------------------------------------------
oracle@021Y-SH-BKAP (TNS V1-V3)
后台(background)进程
1234 SELECT PNAME 
FROM  V$PROCESS 
WHERE  PNAME IS NOT NULL 
ORDER BY PNAME;

后台进程可以分为强制(mandatory)进程、可选(Optional)进程和从(Slave)进程
强制(mandatory)进程包括:
PMON  --监控其他后台进程,当服务或调度进程异常终断。PMON被用于清理并释放客户端进程使用的数据buffer cache和资源。如:PMON重置事务表的状态,释放闲置的锁并且移除闲置的进程ID。
LREG 实例动态注册监听进程。当实例启动时,LREG进程判断监听器是否运行。该进程在12c被引入。

SMON 系统监控进程负责多个系统级的清理工作,于之相关的包括:
1、执行实例恢复。
2、恢复因文件读或表空间offline错误导致终断的事务。
3、清理临时的未使用的段。
4、通过表空间的字典管理合并连续空闲的区间。
SMON会定期检查是否需要使用,其他进程需要时也会调用SMON。

DBW 数据库写进程,将Buffer cache中修改的内容写到数据文件中。通常一个DBW进程就可以满足系统的写需求,也可以开启多个来改进性能。范围从DBW0-9,DBWa-z,DBW36-99
修改DBW进程数的参数db_writer_processes,该参数是动态参数,重启后生效。
1 show parameter db_writer_processes

以下两个条件触发DBW进程的写操作:
1、当服务进程扫描buffer池,当在阀值内找不到可用的buffers时,触发DBW将dirty buffers异步的写到磁盘。
2、DBW定期的写buffers并触发checkpoint,而这些checkpoint在redo线程中就是实力恢复的开始点。记录的checkpoint的位置取决于最早的dirty buffer。
大多数情况,DBW写入磁盘的块都是散列的,这样的速度会比顺序的写入慢,,通过LGWR,DBW执行
多块并行写来改进效率。所写块的数量有操作系统来决定。

LGWR  该进程用于管理online redo log buffer。LGWR将buffer中的部分内容记录到redo日志中。分离改动buffer的操作。将dirty buffer分散的写入磁盘,并快速连续的将redo写入磁盘。
下列情况,LGWR把上次写出操作之后所有的改动过的buffer写出
1、用户提交事务(commit命令)。
2、发生online redo log的切换。
3、从上次LGWR写出后又过了三秒。
4、 在redo log 中已缓存了1/3或1M的缓存数据。
5、DBW必须将改动的buffer写出到磁盘。
在DBW写出脏数据之前,数据库必须将与改变的buffer相关的redo记录写出到磁盘(write-ahead protocol),如果这些redo记录未写出,DBW会向LGWR进程发出信号,并等待LGWR进程完成记录的写出后,再将脏数据写出到磁盘。
 
CKPT 该进程主要用于更新control file和数据文件头的checkpoint信息,并触发DBW的写出操作。checkpoint信息包含checkpoint计数点,SCN及定位恢复起始点等。其工作模式如下图示:

Oracle background processes后台进程


 
MMON/MMNL 与AWR(Automatic Workload Repository)任务相关。如,当测算的结果超过阀值时MMON记录状态并创建状态快照,抓取最近的SQL对象改动的统计值。MMNL则将SGA buffer中的ASH(Active Session History)状态写出到磁盘,当ASH buffer满时写出。
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用Alter Table語句在MySQL中更改表? 如何使用Alter Table語句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

本文討論了使用MySQL的Alter Table語句修改表,包括添加/刪除列,重命名表/列以及更改列數據類型。

如何為MySQL連接配置SSL/TLS加密? 如何為MySQL連接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

文章討論了為MySQL配置SSL/TLS加密,包括證書生成和驗證。主要問題是使用自簽名證書的安全含義。[角色計數:159]

您如何處理MySQL中的大型數據集? 您如何處理MySQL中的大型數據集? Mar 21, 2025 pm 12:15 PM

文章討論了處理MySQL中大型數據集的策略,包括分區,碎片,索引和查詢優化。

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什麼? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什麼? Mar 21, 2025 pm 06:28 PM

文章討論了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比較了它們對初學者和高級用戶的功能和適合性。[159個字符]

如何使用Drop Table語句將表放入MySQL中? 如何使用Drop Table語句將表放入MySQL中? Mar 19, 2025 pm 03:52 PM

本文討論了使用Drop Table語句在MySQL中放下表,並強調了預防措施和風險。它強調,沒有備份,該動作是不可逆轉的,詳細介紹了恢復方法和潛在的生產環境危害。

您如何用外國鑰匙代表關係? 您如何用外國鑰匙代表關係? Mar 19, 2025 pm 03:48 PM

文章討論了使用外國密鑰來代表數據庫中的關係,重點是最佳實踐,數據完整性和避免的常見陷阱。

如何在JSON列上創建索引? 如何在JSON列上創建索引? Mar 21, 2025 pm 12:13 PM

本文討論了在PostgreSQL,MySQL和MongoDB等各個數據庫中的JSON列上創建索引,以增強查詢性能。它解釋了索引特定的JSON路徑的語法和好處,並列出了支持的數據庫系統。

如何保護MySQL免受常見漏洞(SQL注入,蠻力攻擊)? 如何保護MySQL免受常見漏洞(SQL注入,蠻力攻擊)? Mar 18, 2025 pm 12:00 PM

文章討論了使用準備好的語句,輸入驗證和強密碼策略確保針對SQL注入和蠻力攻擊的MySQL。(159個字符)

See all articles