oracle進(jìn)程數(shù)查詢

公司主營(yíng)業(yè)務(wù):成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。成都創(chuàng)新互聯(lián)公司推出鳩江免費(fèi)做網(wǎng)站回饋大家。
1.cmd
2.sqlplus /nolog
3.connect sys/test@test as sysdba
SQL show parameter process;
NAME???????????????????????????????? TYPE??????? VALUE
------------------------------------ ----------- -----
aq_tm_processes????????????????????? integer???? 0
db_writer_processes????????????????? integer???? 1
gcs_server_processes???????????????? integer???? 0
job_queue_processes????????????????? integer???? 10
log_archive_max_processes??????????? integer???? 2
processes??????????????????????????? integer???? 1000
再查進(jìn)程數(shù)
SQL select count(*) from v$session;
COUNT(*)
----------
224
查看ORACLE最大進(jìn)程數(shù):
SQL select count(*) from v$session ?#連接數(shù)
SQL Select count(*) from v$session where status='ACTIVE' #并發(fā)連接數(shù)
SQL show parameter processes ?#最大連接
SQL alter system set processes = value scope = spfile;重啟數(shù)據(jù)庫(kù) ?#修改連接
unix 1個(gè)用戶session 對(duì)應(yīng)一個(gè)操作系統(tǒng) process
而 windows體現(xiàn)在線程
------------------------------------------------------------------------------
修改ORACLE最大進(jìn)程數(shù):
使用sys,以sysdba權(quán)限登錄:
SQL show parameter processes;
NAME ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? TYPE ? ? ? ?VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes ? ? ? ? ? ? ? ? ? ? ?integer ? ? 1
db_writer_processes ? ? ? ? ? ? ? ? ?integer ? ? 1
job_queue_processes ? ? ? ? ? ? ? ? ?integer ? ? 10
log_archive_max_processes ? ? ? ? ? ?integer ? ? 1
processes ? ? ? ? ? ? ? ? ? ? ? ? ? ?integer ? ? 150
SQL alter system set processes=300 scope = spfile;
系統(tǒng)已更改。
SQL show parameter processes;
NAME ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? TYPE ? ? ? ?VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes ? ? ? ? ? ? ? ? ? ? ?integer ? ? 1
db_writer_processes ? ? ? ? ? ? ? ? ?integer ? ? 1
job_queue_processes ? ? ? ? ? ? ? ? ?integer ? ? 10
log_archive_max_processes ? ? ? ? ? ?integer ? ? 1
processes ? ? ? ? ? ? ? ? ? ? ? ? ? ?integer ? ? 150
SQL create pfile from spfile;
文件已創(chuàng)建。
重啟數(shù)據(jù)庫(kù),
SQL show parameter processes;
NAME ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? TYPE ? ? ? ?VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes ? ? ? ? ? ? ? ? ? ? ?integer ? ? 1
db_writer_processes ? ? ? ? ? ? ? ? ?integer ? ? 1
job_queue_processes ? ? ? ? ? ? ? ? ?integer ? ? 10
log_archive_max_processes ? ? ? ? ? ?integer ? ? 1
processes ? ? ? ? ? ? ? ? ? ? ? ? ? ?integer ? ? 300
Oracle數(shù)據(jù)庫(kù)查看一個(gè)進(jìn)程是如何執(zhí)行相關(guān)的實(shí)際SQL語(yǔ)句
SELECT b.sql_text, sid, serial#, osuser, machine
FROM v$session a, v$sqlarea b
WHERE a.sql_address = b.address;
查詢前臺(tái)發(fā)出的SQL語(yǔ)句.
select user_name,sql_text
from v$open_cursor
where sid in
(select sid from (select sid,serial#,username,program from v$session where status='ACTIVE'));
根據(jù)SPID查詢session
SELECT * FROM v$session WHERE paddr IN
(SELECT addr FROM v$process WHERE spid=spid);
根據(jù)SID查詢process
SELECT * FROM v$process WHERE addr IN
(SELECT paddr FROM v$session WHERE sid=sid);
DBA如何查詢其他用戶所進(jìn)行的操作
SELECT sql_text
FROM v$sql t1, v$session t2
WHERE t1.address = t2.sql_address
AND t2.sid = sid;
根據(jù)process查詢sql語(yǔ)句
SELECT sql_text
FROM v$sqltext a
WHERE (a.hash_value, a.address) IN (
SELECT DECODE (sql_hash_value,0, prev_hash_value,sql_hash_value ),
DECODE (sql_hash_value, 0, prev_sql_addr, sql_address)
FROM v$session b
WHERE b.paddr = (SELECT addr
FROM v$process c
WHERE c.spid = '$processID'))
ORDER BY piece ASC;
其他
執(zhí)行下列命令語(yǔ)句
sqlplus / as sysdba EOF
create tablespace test datafile '/data/test01.dbf' size 10240M;
quit;
EOF
通過(guò)ps -ef|grep sqlplus命令得到上面所執(zhí)行的命令的進(jìn)程id為:12345
(1)關(guān)于v$process
執(zhí)行下面的SQL是查不到相關(guān)的信息:
select * from v$process where spid='12345';
因?yàn)檫@個(gè)spid字段對(duì)應(yīng)的并不是我們用ps命令從系統(tǒng)中查詢到的進(jìn)程id,而是這個(gè)進(jìn)程執(zhí)行的當(dāng)前SQL的進(jìn)程id,
也就是上面命令中的“create tablespace test datafile '/data/test01.dbf' size 10240M;”所對(duì)應(yīng)的進(jìn)程id,如果想
通過(guò)用ps命令從系統(tǒng)中查詢到的進(jìn)程id查看對(duì)應(yīng)的信息,那么必須使用下面語(yǔ)句:
select spid,sid,process,sql_address from v$session where process='12345'
上面sql中的process就是通過(guò)ps查看的進(jìn)程id,而spid就是里面的sql語(yǔ)句所對(duì)應(yīng)的進(jìn)程id。
還可以通過(guò)上面的sql_address 查看正在執(zhí)行的SQL語(yǔ)句內(nèi)容:
select sql_text from v$sqlarea s,v$session ses where s.address=ses.sql_address and ses.process='12345';
(2)關(guān)于v$session
在查詢 v$session 視圖的時(shí)候,我們根據(jù)command字段內(nèi)部表示解碼每一個(gè)字段,當(dāng)我們需要快速找出他們的 Oracle 系統(tǒng)的內(nèi)部情況時(shí)非常有用。
select
substr(s.username,1,18) username,substr(s.program,1,15) program,p.spid,s.process,
decode(s.command,
0,'No Command',
1,'Create Table',
2,'Insert',
3,'Select',
6,'Update',
7,'Delete',
9,'Create Index',
15,'Alter Table',
21,'Create View',
23,'Validate Index',
35,'Alter Database',
39,'Create Tablespace',
41,'Drop Tablespace',
40,'Alter Tablespace',
53,'Drop User',
62,'Analyze Table',
63,'Analyze Index',
s.command||': Other') command
from
v$session s,
v$process p,
v$transaction t,
v$rollstat r,
v$rollname n
where s.paddr = p.addr
and s.taddr = t.addr (+)
and t.xidusn = r.usn (+)
and r.usn = n.usn (+)
order by username
(3)幾個(gè)相關(guān)的SQL
--查看系統(tǒng)進(jìn)程對(duì)應(yīng)的信息
select se.saddr,se.sid,se.serial#,p.pid,se.paddr,s.sql_id,s.sql_text
from v$session se ,v$process p, v$sqlarea s
where se.paddr=p.addr and se.sql_address=s.address and se.process='1'
and se.username is not null
--查看所有的會(huì)話
select se.username,se.saddr,se.sid,se.serial#,se.process,s.sql_id
from v$session se,v$sqlarea s
where se.sql_address=s.address
--查看會(huì)話對(duì)應(yīng)的sql內(nèi)容
select se.username,se.process,s.sql_text
from v$session se,v$sqlarea s
where se.sql_address=s.address and s.sql_id='1'
oracle 如何查找和kill 對(duì)應(yīng)的job進(jìn)程
查找當(dāng)前被鎖住的進(jìn)程:
SELECT object_name, s.sid, s.serial#, p.spid
FROM v$locked_object l, dba_objects o, v$session s, v$process p
WHERE l.object_id = o.object_id
AND l.session_id = s.sid
AND s.paddr = p.addr;
Kill 對(duì)應(yīng)的Oracle Session
應(yīng)為BROKEN后該JOB還在運(yùn)行,如果要求該JOB立刻停止,就需要找到該job的對(duì)應(yīng)SESSION(SID,SERIAL#),然后執(zhí)行以下命令:
ALTER SYSTEM KILL SESSION 'sid,serial#';
將Job Queue Processes的數(shù)目修改為0
首先確認(rèn)當(dāng)前的Job Queue Processes的數(shù)目
SQL select name,value from v$parameter where name ='job_queue_processes';
然后將Job Queue Processes的數(shù)目修改為0
ALTER SYSTEM SET job_queue_processes = 0;
保證所有的JOB都會(huì)停止。
恢復(fù)job_queue_processes的原始值
ALTER SYSTEM SET job_queue_processes = original_value;
使用sqlplus登錄到sysdba,可以用數(shù)據(jù)字典查詢數(shù)據(jù)庫(kù)狀態(tài)。正常開(kāi)啟的話狀態(tài)應(yīng)該是 OPEN select status from v$instance; 如果是RAC集群,可以使用CRS命令查看整個(gè)集群的實(shí)例運(yùn)行狀態(tài): su -oracle crs_stat -t
查看ORACLE最大進(jìn)程數(shù):
SQL select count(*) from v$session #連接數(shù)
SQL Select count(*) from v$session where status='ACTIVE' #并發(fā)連接數(shù)
SQL show parameter processes #最大連接
SQL alter system set processes = value scope = spfile;重啟數(shù)據(jù)庫(kù) #修改連接
unix 1個(gè)用戶session 對(duì)應(yīng)一個(gè)操作系統(tǒng) process
而 windows體現(xiàn)在線程
------------------------------------------------------------------------------
修改ORACLE最大進(jìn)程數(shù):
使用sys,以sysdba權(quán)限登錄:
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL alter system set processes=300 scope = spfile;
系統(tǒng)已更改。
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 150
SQL create pfile from spfile;
文件已創(chuàng)建。
重啟數(shù)據(jù)庫(kù),
SQL show parameter processes;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
db_writer_processes integer 1
job_queue_processes integer 10
log_archive_max_processes integer 1
processes integer 300
oracle占用cpu過(guò)高怎么處理,本文將介紹有關(guān)oracle進(jìn)程CPU占用率過(guò)高的問(wèn)題,需要了解跟多的朋友可以參考下
1:首先使用TOP命令傳到占用CPU高的SPID號(hào)
PID USERNAME THR PRI NICE SIZE RES STATE TIME CPU COMMAND
3575 oracle 1 12 0 0K 0K run 748.6H 24.98% oracle
3571 oracle 1 22 0 0K 0K sleep 706.2H 22.84% oracle
2:使用DBA賬戶登錄數(shù)據(jù)庫(kù),使用以下SQL語(yǔ)句查詢:
SELECT * FROM V$PROCESS WHERE spid=3575;查詢到SQL相關(guān)信息
3:根據(jù)以上查詢到的信息使用以下SQL查詢:
SELECT sid, program FROM V$SESSION S WHERE EXISTS(SELECT 1 FROM V$PROCESS WHERE spid=3575 AND ADDR = S.PADDR);
可以查詢到具體那個(gè)客戶端查詢一直在不斷占用ORACLE資源!
最后對(duì)這個(gè)查詢進(jìn)行處理!
4.根據(jù)SID查得SQLITPUB
復(fù)制代碼代碼如下:
select sql_textITPUB
from v$sqltext
where a.hashvalue=(select sql_hash_value
from v$session b
where b.SID='sid')
0order by piece ASC;
根據(jù)lockwait字段可以查詢當(dāng)前正在等待的鎖的相關(guān)信息:
復(fù)制代碼代碼如下:
select * from v$lock where kaddr in (select lockwait from v$session where sid= $sid);
(sql_address,sql_hash_value),(prev_sql_addr,prev_hash_value) 根據(jù)這兩組字段, 可以查詢到當(dāng)前session正在執(zhí)行的或最近一次執(zhí)行的sql語(yǔ)句的詳細(xì)信息:
select * from v$sqltext where address = sql_address and hash_value = sql_hash_value;
根據(jù)PID查SQL相關(guān)信息:
復(fù)制代碼代碼如下:
select id,serial# ,username,osuser,machine,program,process,to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') logon from v$session where paddr in ( select addr from v$process where spid in('pid'));
根據(jù)PID查SQL語(yǔ)句
復(fù)制代碼代碼如下:
SELECT a.username,a.machine,a.program,a.sid,a.serial#,a.status,c.piece,c.sql_text FROM v$session a,v$process b,v$sqltext c WHERE b.spid='spid' AND b.addr=a.paddr AND a.sql_address=c.address(+) ORDER BY c.piece;
得到進(jìn)程的sid號(hào):
復(fù)制代碼代碼如下:
select id,serial# ,username,osuser,machine,program,process,to_char(logon_time,'yyyy/mm/dd hh24:mi:ss') logon from v$session where paddr in ( select addr from v$process where spid in('pid'));
得到session的sqltext語(yǔ)句:
復(fù)制代碼代碼如下:
select sql_text from v$sqltext_with_newlines where hash_value in (select SQL_HASH_VALUE from v$session where paddr in (select addr from v$process where spid= 'pid')) order by piece;
網(wǎng)頁(yè)標(biāo)題:oracle如何查詢進(jìn)程,oracle數(shù)據(jù)庫(kù)進(jìn)程
分享URL:http://chinadenli.net/article12/hcpdgc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、虛擬主機(jī)、自適應(yīng)網(wǎng)站、關(guān)鍵詞優(yōu)化、網(wǎng)站收錄、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容