ask Tom解釋 connect processes sesssions 的區別
ask Tom解釋的很清楚,如下[@more@]
You Asked
Hi Tom What's the difference between connections, sessions and processes? I read a note from Metalink about the difference but I simply dont get it! May you give a brief explanation? Thank you
and we said...
A process is a physical process or thread. On unix, you can see a process with "ps" for example. It is there. There are many types of processes in Oracle -- background processes like SMON, PMON, RECO, ARCH, CKPT, EMNn, DBWR, etc..... And user processes like dedicated servers or shared server (multi-threaded server -- aka MTS -- configuration) A connection is a "physical circuit", a pathway to a database. You can be connected to a database yet have 0 or 1 or MORE sessions going on that connection. We can see that with sqlplus, consider (single user system here, its all about me) [tkyte@tkyte-pc-isdn tkyte]$ ps -auxww | grep oracleora920 [tkyte@tkyte-pc-isdn tkyte]$ sqlplus /nolog SQL*Plus: Release 9.2.0.1.0 - Production on Sat Sep 28 10:36:03 2002 Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved. idle> !ps -auxww | grep oracleora920 tkyte 19971 0.0 0.1 2196 916 pts/1 S 10:36 0:00 /bin/bash -c ps -auxww | grep oracleora920 tkyte 19973 0.0 0.1 1736 564 pts/1 S 10:36 0:00 grep oracleora920 no process, no nothing idle> connect / Connected. idle> !ps -auxww | grep oracleora920 ora920 19974 1.5 2.2 230976 11752 ? S 10:36 0:00 oracleora920 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq))) tkyte 19975 0.0 0.1 2196 916 pts/1 S 10:36 0:00 /bin/bash -c ps -auxww | grep oracleora920 tkyte 19977 0.0 0.1 1736 564 pts/1 S 10:36 0:00 grep oracleora920 got my process now... idle> disconnect Disconnected from Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production With the Partitioning, OLAP and Oracle Data Mining options JServer Release 9.2.0.1.0 - Production idle> !ps -auxww | grep oracleora920 ora920 19974 0.6 2.3 230976 11876 ? S 10:36 0:00 oracleora920 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq))) tkyte 19978 0.0 0.1 2196 916 pts/1 S 10:36 0:00 /bin/bash -c ps -auxww | grep oracleora920 tkyte 19980 0.0 0.1 1736 564 pts/1 S 10:36 0:00 grep oracleora920 idle> select * from dual; SP2-0640: Not connected still have my process, but no session, the message is a little "misleading". Technically -- I have a connection, I don't have a session further, autotrace in sqlplus can be used to show that you can have a) a connection b) that uses a single process c) to service two sessions: ops$tkyte@ORA920.US.ORACLE.COM> select username from v$session where username is not null; USERNAME ------------------------------ OPS$TKYTE one session, ME ops$tkyte@ORA920.US.ORACLE.COM> select username, program from v$process; USERNAME PROGRAM --------------- ------------------------------------------------ PSEUDO ora920 oracle@tkyte-pc-isdn.us.oracle.com (PMON) ora920 oracle@tkyte-pc-isdn.us.oracle.com (DBW0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (LGWR) ora920 oracle@tkyte-pc-isdn.us.oracle.com (CKPT) ora920 oracle@tkyte-pc-isdn.us.oracle.com (SMON) ora920 oracle@tkyte-pc-isdn.us.oracle.com (RECO) ora920 oracle@tkyte-pc-isdn.us.oracle.com (CJQ0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (QMN0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (S000) ora920 oracle@tkyte-pc-isdn.us.oracle.com (D000) ora920 oracle@tkyte-pc-isdn.us.oracle.com (ARC0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (ARC1) tkyte oracle@tkyte-pc-isdn.us.oracle.com (TNS V1-V3) 14 rows selected. you can see all of the backgrounds and my dedicated server... ops$tkyte@ORA920.US.ORACLE.COM> set autotrace on statistics; Autotrace for statistics uses ANOTHER session so it can query up the stats for your CURRENT session without impacting the STATS for that session! ops$tkyte@ORA920.US.ORACLE.COM> select username from v$session where username is not null; USERNAME ------------------------------ OPS$TKYTE OPS$TKYTE see, two sessions but.... Statistics ---------------------------------------------------------- 0 recursive calls 0 db block gets 0 consistent gets 0 physical reads 0 redo size 418 bytes sent via SQL*Net to client 499 bytes received via SQL*Net from client 2 SQL*Net roundtrips to/from client 0 sorts (memory) 0 sorts (disk) 2 rows processed ops$tkyte@ORA920.US.ORACLE.COM> select username, program from v$process; USERNAME PROGRAM --------------- ------------------------------------------------ PSEUDO ora920 oracle@tkyte-pc-isdn.us.oracle.com (PMON) ora920 oracle@tkyte-pc-isdn.us.oracle.com (DBW0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (LGWR) ora920 oracle@tkyte-pc-isdn.us.oracle.com (CKPT) ora920 oracle@tkyte-pc-isdn.us.oracle.com (SMON) ora920 oracle@tkyte-pc-isdn.us.oracle.com (RECO) ora920 oracle@tkyte-pc-isdn.us.oracle.com (CJQ0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (QMN0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (S000) ora920 oracle@tkyte-pc-isdn.us.oracle.com (D000) ora920 oracle@tkyte-pc-isdn.us.oracle.com (ARC0) ora920 oracle@tkyte-pc-isdn.us.oracle.com (ARC1) tkyte oracle@tkyte-pc-isdn.us.oracle.com (TNS V1-V3) 14 rows selected. same 14 processes... Statistics ---------------------------------------------------------- 0 recursive calls 0 db block gets 0 consistent gets 0 physical reads 0 redo size 1095 bytes sent via SQL*Net to client 499 bytes received via SQL*Net from client 2 SQL*Net roundtrips to/from client 0 sorts (memory) 0 sorts (disk) 14 rows processed ops$tkyte@ORA920.US.ORACLE.COM> I'll try to put it into a single, simple paragraph: A connection is a physical circuit between you and the database. A connection might be one of many types -- most popular begin DEDICATED server and SHARED server. Zero, one or more sessions may be established over a given connection to the database as show above with sqlplus. A process will be used by a session to execute statements. Sometimes there is a one to one relationship between CONNECTION->SESSION->PROCESS (eg: a normal dedicated server connection). Sometimes there is a one to many from connection to sessions (eg: like autotrace, one connection, two sessions, one process). A process does not have to be dedicated to a specific connection or session however, for example when using shared server (MTS), your SESSION will grab a process from a pool of processes in order to execute a statement. When the call is over, that process is released back to the pool of processes.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/271063/viewspace-1008036/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Ask Tom!解決你的Oracle疑難雜症Oracle
- Android程式(Processes)和任務(tasks)的區別Android
- 解釋和編譯的區別編譯
- Oracle中的Connect、session、process的區別OracleSession
- 堆和棧的解釋和區別
- Introduction to processes and threads(執行緒與程式的區別)thread執行緒
- 註解和註釋區別
- [OC]之 atomic 與 nonatomic的區別
- apache和tomcat的區別ApacheTomcat
- Ask Hoegh(5)——buffer cache和buffer有什麼區別?
- Apache、Nginx、Tomcat、PHP的區別ApacheNginxTomcatPHP
- 你知道「編譯」與「解釋」的區別嗎?編譯
- DIFFERENCES BETWEEN PROCESSES, SESSIONS AND CONNECTIONS(asktom)Session
- 編譯程式與解釋程式區別?編譯
- Websocket:TomCat7 與 TomCat8的區別WebTomcat
- Key-preserved table concept in join view (Ask Tom)View
- weblogic,tomcat,JBoss以及Websphere的區別WebTomcat
- 關於機器學習和AI的區別最經典的解釋機器學習AI
- SAP Cloud for Customer Account和individual customer的區別Cloud
- Apache與Tomcat 區別聯絡ApacheTomcat
- QObject Event( )customEvent( ) 函式區別Object函式
- Nginx/Tomcat/Apache的優缺點和區別NginxTomcatApache
- 解釋型語言與編譯型語言的區別?編譯
- 【ASK_ORACLE】Library cache pin 與 library load lock的關係和區別Oracle
- 解釋型語言、編譯型語言 區別編譯
- Apache Http Server和Tomcat 之區別ApacheHTTPServerTomcat
- Ask Hoegh(4)——select count(*)和select count(1)、count(column)有區別嗎?
- iOS中atomic和nonatomic區別及內部實現iOS
- Tomcat安裝目錄解釋Tomcat
- 精通Oracle的關鍵是……(Ask Tom上最經常被問到的問題)Oracle
- oracle中的processes,session,transaction引數詳解OracleSession
- Tomcat 部署時 war 和 war exploded 區別Tomcat
- Tomcat部署時war和war exploded區別Tomcat
- [轉]Apache與Tomcat 區別及聯絡ApacheTomcat
- SAP Cloud for Customer裡BusinessPartner, Customer和Employee這些BO的區別Cloud
- 【PB】PB中object,control,custom class,custom visual,custom external等概念的區別Object
- equals與==的區別(詳解)
- 測試案例testWeb在tomcat5.0和tomcat5.5中的配置區別?WebTomcat