溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

對(duì)于會(huì)話sniped和inactive的理解,一邊設(shè)置idle_time和sqlnet.expired_time

發(fā)布時(shí)間:2020-08-15 01:09:16 來(lái)源:ITPUB博客 閱讀:223 作者:數(shù)據(jù)小魏 欄目:關(guān)系型數(shù)據(jù)庫(kù)



1、什么是SNIPED會(huì)話?

     當(dāng)一個(gè)會(huì)話是INACTIVE的,且INACTIVE的時(shí)長(zhǎng)超過(guò)了某個(gè)限制,比如PROFILE中指定的IDLE_TIME時(shí),這個(gè)會(huì)話的狀態(tài)就會(huì)從INACTIVE變?yōu)镾INPED。

     以你的例子來(lái)說(shuō),就是當(dāng)一個(gè)非活動(dòng)會(huì)話的空閑時(shí)間超過(guò)了360分鐘,該會(huì)話的狀態(tài)就會(huì)變?yōu)镾NIPED。而不是360分鐘后清理掉SNIPED的會(huì)話。


2、SNIPED會(huì)話何時(shí)被清理?

     當(dāng)被標(biāo)記為SNIPED的會(huì)話的客戶端再次發(fā)出SQL語(yǔ)句時(shí),客戶端會(huì)收到錯(cuò)誤提示,比如ORA-02396: exceeded maximum idle time, please connect again。這時(shí),數(shù)據(jù)庫(kù)才會(huì)徹底清理掉該會(huì)話及操作系統(tǒng)上的連接。

     但這樣一來(lái),意味著如果客戶端不發(fā)出SQL,則不能清理掉的SNIPED的會(huì)話及其使用的連接,它們?nèi)匀粫?huì)占用著資源,這可能引起資源不足的報(bào)錯(cuò),比如連接數(shù)達(dá)到最大的問(wèn)題。這時(shí),就需要手工來(lái)清理這些SINPED會(huì)話及其所使用的連接。


3、手工清理SNIPED會(huì)話的腳本


查詢狀態(tài)為SNIPED的spid的命令:

SELECT P.SPID from V$PROCESS P,V$SESSION S

WHERE S.PADDR=P.ADDR

and s.STATUS = 'SNIPED';


查詢狀態(tài)為SNIPED 或 INACTIVE 的spid的命令:

SELECT P.SPID from V$PROCESS P,V$SESSION S

WHERE S.PADDR=P.ADDR

and s.STATUS in  ('SNIPED','INACTIVE');


查詢上述兩種狀態(tài),并定位用戶:

SELECT P.SPID from V$PROCESS P,V$SESSION S

WHERE S.PADDR=P.ADDR

and S.STATUS = 'SNIPED'

and S.USERNAME = 'TTT';


腳本內(nèi)容:

snfile=/tmp/tmp.txt

sqlplus system/oracle <<EOF

spool $snfile

@/home/oracle/123.sql

spool off

exit;

EOF

for x in `cat /tmp/tmp.txt | grep "^[0123456789]"`

do

kill -9 $x

done

rm /tmp/tmp.txt


當(dāng)你的數(shù)據(jù)庫(kù)連接方式為共享連接時(shí),要小心不要把分配器進(jìn)程或共享服務(wù)器進(jìn)程也一并殺掉了。

對(duì)于10.2版本以上的數(shù)據(jù)庫(kù)且是專用連接方式的,ORACLE推薦使用:

ALTER SYSTEM DISCONNECT SESSION '<SID>,<SERIAL>' IMMEDIATE 來(lái)清理。



4、在sqlnet.ora中配置SQLNET.EXPIRE_TIME=xxx,就是啟用了DCD功能。其工作原理是當(dāng)連接建立后,每隔XXX分鐘,就由服務(wù)器端發(fā)送一個(gè)探測(cè)包到客戶端,如果收到錯(cuò)誤信息,就標(biāo)記該連接并通知操作系統(tǒng)釋放連接,回收資源。




向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI