[20171120]理解v$session的state字段

[20171120]理解v$session的state字段(11G).txt

--//https://blogs.oracle.com/database4cn/vsession-%e4%bd%a0%e7%9c%8b%e5%88%b0%e7%9a%84event%e7%9c%9f%e7%9a%84%e6%98%afsession%e5%bd%93%e5%89%8d%e7%9a%84%e7%ad%89%e5%be%85%e4%ba%8b%e4%bb%b6%e4%b9%88-v2
--//v$session - 你看到的event真的是session当前的等待事件么?
--//我重复测试,其内容直接转抄作者的链接:

SCOTT@book> @ ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//sesson 1:
SCOTT@book> @ &r/spid

       SID    SERIAL# PROCESS                  SERVER    SPID       PID  P_SERIAL# C50
---------- ---------- ------------------------ --------- ------ ------- ---------- --------------------------------------------------
       274          5 53785                    DEDICATED 53786       21          3 alter system kill session '274,5' immediate;
--//记下sid=274.

SCOTT@test01p> exec loop null; end loop;
--//死循环.

--//sesson 2:

SCOTT@book> @ &r/wait
no rows selected

--//嗯,没有输出,看来我的检测脚本要修改看看.
SCOTT@book> select sid,serial#,status,sql_id,event,seq# from v$session where sid=274;

       SID    SERIAL# STATUS   SQL_ID        EVENT                                          SEQ#
---------- ---------- -------- ------------- ---------------------------------------- ----------
       274          5 ACTIVE   61bj68pvygxvz SQL*Net message from client                      40

SCOTT@book> @ &r/sqlid 61bj68pvygxvz
SQL_ID        SQLTEXT
------------- --------------------------------
61bj68pvygxvz BEGIN loop null; end loop; END;

您会发现以上这个session竟然会在 "等待" SQL*Net message from client,并且status为ACTIVE,大家都知道SQL*Net message from
client是一个空闲等待,代表server process正在等待client发出下一个sql指令。

接下来观察以上以上进程的CPU消耗情况,会发现它在持续的ON CPU

$ top -p 53786 -b
top - 11:03:32 up 711 days,  2:26,  1 user,  load average: 1.21, 0.62, 0.37
Tasks:   1 total,   1 running,   0 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.2%us,  1.0%sy,  0.0%ni, 98.8%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  132261196k total, 113979744k used, 18281452k free,  1122908k buffers
Swap: 31455264k total,     2300k used, 31452964k free, 108723604k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
53786 oracle    20   0  849m  27m  23m R 99.8  0.0   2:07.03 oracle

--//它几乎消耗了一个的CPU.

那么问题来了,这个如此烧CPU的死循环session怎么会是处于空闲等待?答案是我们忽略了v$session.state这个非常重要的列。

一个session的状态要么是在等待,要么是在ON CPU,v$session.state这个列可以判断这个状态。有且只有v$session.state='WAITING'
的时候,才代表这个session当前正在等待这个event,否则代表这个session在ON CPU,并且观察到的event只是进程在ON CPU之前的最后
一个等待。

接下来我们将以上用于查询session等待的SQL改一下,添加上v$session.state这个列:

SCOTT@book> select sid,serial#,status,state,sql_id,event,seq# from v$session where sid=274;
       SID    SERIAL# STATUS   STATE               SQL_ID        EVENT                                          SEQ#
---------- ---------- -------- ------------------- ------------- ---------------------------------------- ----------
       274          5 ACTIVE   WAITED KNOWN TIME   61bj68pvygxvz SQL*Net message from client                      40

可见STATE的值为"WAITED KNOWN TIME",不是"WAITING",这表明这个session当前在ON CPU,"SQL*Net message from client"只是这个
session在ON CPU之前的最后一个等待。因此当您查询v$session观察session的等待事件的时候,一定不要忘了v$session.state这个关键
列。
     
--//看来给修改我的检测脚本:
select p1raw,p2raw,p3raw,p1,p2,p3,sid,serial#,seq#,event,state,wait_time_micro,seconds_in_wait
from v$session where wait_class<>'Idle'
and sid not in (select sid from v$mystat where rownum=1)
order by event ;

--//修改如下:

select p1raw,p2raw,p3raw,p1,p2,p3,sid,serial#,seq#,event,status,state,wait_time_micro,seconds_in_wait
from v$session where ( wait_class<>'Idle' or (status='ACTIVE' and STATE='WAITED KNOWN TIME'))
and sid not in (select sid from v$mystat where rownum=1)
order by event ;

SCOTT@book> @ &r/wait
P1RAW            P2RAW            P3RAW                    P1         P2         P3        SID    SERIAL#       SEQ# EVENT                                    STATUS   STATE               WAIT_TIME_MICRO SECONDS_IN_WAIT
---------------- ---------------- ---------------- ---------- ---------- ---------- ---------- ---------- ---------- ---------------------------------------- -------- ------------------- --------------- ---------------
0000000062657100 0000000000000001 00               1650815232          1          0        274          5         40 SQL*Net message from client              ACTIVE   WAITED KNOWN TIME          15932642             357

时间: 2024-08-26 12:28:49

[20171120]理解v$session的state字段的相关文章

[20171102]视图v$session中process字段含义

[20171102]视图v$session中process字段含义.txt --//被别人问及这个问题,自己也简单测试看看.我记忆里看warehouse的教学视频,好像提到的client端的进程号. 1.环境: SCOTT@book> @ &r/ver1 PORT_STRING                    VERSION        BANNER ------------------------------ -------------- ---------------------

理解PHP中的Session及对Session有效期的控制_php技巧

0.什么是session?       Session的中文译名叫做"会话",其本来的含义是指有始有终的一系列动作/消息,比如打电话时从拿起电话拨号到挂断电话这中间的一系列过程可以称之为一个session.目前社会上对session的理解非常混乱:有时候我们可以看到这样的话"在一个浏览器会话期间,...",这里的会话是指从一个浏览器窗口打开到关闭这个期间:也可以看到"用户(客户端)在一次会话期间"这样一句话,它可能指用户的一系列动作(一般情况下是

【会话】V$SESSION视图

[会话]V$SESSION视图 讲到Oracle的会话,就必须首先对V$SESSION这个视图中的每个列都非常熟悉.该视图在Oracle 11gR2下包含97列,在Oracle 12cR2下增加了6列,共包含103列.下面作者以表格的形式对这个视图中的重要列做详细说明. 表 3-26 V$SESSION视图 V$SESSION displays session information for each current session. 视图列序号 列 数据类型 说明 官方解释 备注 1 SADD

【会话】Oracle kill session系列

[会话]Oracle kill session系列   1.1  BLOG文档结构图 Oracle kill session相关问题 - 3 - 1.1 BLOG文档结构图 - 4 - 1.2 前言部分 - 5 - 1.2.1 导读和注意事项 - 5 - 1.2.2 相关参考文章链接 - 6 - 1.2.3 本文简介 - 7 - 1.3 相关知识点扫盲(摘自网络+个人总结) - 7 - 1.3.1 得到当前会话的几个SQL - 7 - 1.3.2 Session 状态说明 - 8 - 1.3.3

理解 Ajax 及其工作原理,构建网站的一种有效方法

ajax Ajax 由 HTML.JavaScript 技术.DHTML 和 DOM 组成,这一杰出的方法可以将笨拙的 Web 界面转化成交互性的 Ajax 应用程序.本文的作者是一位 Ajax 专家,他演示了这些技术如何协同工作 -- 从总体概述到细节的讨论 -- 使高效的 Web 开发成为现实.他还揭开了 Ajax 核心概念的神秘面纱,包括 XMLHttpRequest 对象. <--START RESERVED FOR FUTURE USE INCLUDE FILES--><--

ASP.NET Session的七点认识

ASP.NET Session的使用当中我们会遇到很多的问题,那么这里我们来谈下经常出现的一些常用ASP.NET Session的理解: ASP.NET Session的七点认识之一 对于值类型的变量,Session中保存的是值类型的拷贝 Session["__test0"] = 1;  int i = (int)Session["__test0"]+1;  int j = (int)Session["__test0"]; 结果i=2,j=1 A

这里我们可以看到:Person是个多层次对象,包含多层嵌入属性对象(multi-layer embeded objects)。如果需要更改Person类型实例中的任何字段时,我们可以直接用行令方式(imperative style):

  scala中的case class是一种特殊的对象:由编译器(compiler)自动生成字段的getter和setter.如下面的例子: 1 case class City(name:String, province: String) 2 case class Address(street: String, zip: String, city: City) 3 case class Person(name: String, age: Int, phone: String, address:

PHP 之session cookie

cookie和session有什么用?   常见的用法,比如在有些网站下载东西需要会员先登陆.http协议本身是无状态的,无法得知顾客是否已经登陆,怎么办呢?cookie和session就可以知道.再比如网上购物,用户身份认证,程序状态记录.购物车怎么知道顾客挑选过哪些商品呢?cookie和session也可以记录.总而言之,cookie和session就是能够记录顾客状态的技术,尽管二者属于不同的技术,但只要cookie能做到的,session也能做到!如果session和cookie一样安全

ASP.NET Session的七点认识小结_实用技巧

ASP.NET Session的七点认识之一 对于值类型的变量,Session中保存的是值类型的拷贝 Session["__test0"] = 1; int i = (int)Session["__test0"]+1; int j = (int)Session["__test0"]; 结果i=2,j=1 ASP.NET Session的七点认识之二 对于引用类新的变量,Session中保存的是引用 CDACommon cda = new CDAC