91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

對于會話sniped和inactive的理解,一邊設置idle_time和sqlnet.expired_time

發布時間:2020-08-15 01:09:16 來源:ITPUB博客 閱讀:223 作者:數據小魏 欄目:關系型數據庫



1、什么是SNIPED會話?

     當一個會話是INACTIVE的,且INACTIVE的時長超過了某個限制,比如PROFILE中指定的IDLE_TIME時,這個會話的狀態就會從INACTIVE變為SINPED。

     以你的例子來說,就是當一個非活動會話的空閑時間超過了360分鐘,該會話的狀態就會變為SNIPED。而不是360分鐘后清理掉SNIPED的會話。


2、SNIPED會話何時被清理?

     當被標記為SNIPED的會話的客戶端再次發出SQL語句時,客戶端會收到錯誤提示,比如ORA-02396: exceeded maximum idle time, please connect again。這時,數據庫才會徹底清理掉該會話及操作系統上的連接。

     但這樣一來,意味著如果客戶端不發出SQL,則不能清理掉的SNIPED的會話及其使用的連接,它們仍然會占用著資源,這可能引起資源不足的報錯,比如連接數達到最大的問題。這時,就需要手工來清理這些SINPED會話及其所使用的連接。


3、手工清理SNIPED會話的腳本


查詢狀態為SNIPED的spid的命令:

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

WHERE S.PADDR=P.ADDR

and s.STATUS = 'SNIPED';


查詢狀態為SNIPED 或 INACTIVE 的spid的命令:

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

WHERE S.PADDR=P.ADDR

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


查詢上述兩種狀態,并定位用戶:

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

WHERE S.PADDR=P.ADDR

and S.STATUS = 'SNIPED'

and S.USERNAME = 'TTT';


腳本內容:

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


當你的數據庫連接方式為共享連接時,要小心不要把分配器進程或共享服務器進程也一并殺掉了。

對于10.2版本以上的數據庫且是專用連接方式的,ORACLE推薦使用:

ALTER SYSTEM DISCONNECT SESSION '<SID>,<SERIAL>' IMMEDIATE 來清理。



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




向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

额济纳旗| 峨眉山市| 上虞市| 榆中县| 连城县| 开平市| 治县。| 津市市| 万盛区| 清流县| 杨浦区| 辛集市| 子长县| 万州区| 安平县| 轮台县| 大冶市| 清丰县| 叶城县| 巴楚县| 罗城| 宜兰市| 武安市| 长岭县| 石城县| 利津县| 新建县| 中卫市| 大邑县| 定南县| 武乡县| 旬邑县| 武冈市| 赤城县| 禄丰县| 泰宁县| 青海省| 将乐县| 毕节市| 乐安县| 荔波县|