设为首页 收藏本站
查看: 846|回复: 0

[经验分享] Oracle 动态性能表 v$session & v$process

[复制链接]

尚未签到

发表于 2016-8-6 13:21:55 | 显示全部楼层 |阅读模式
  整理自google出来的网络资源。google是个好东东。没有google我会心神不宁。
  
  v$session
  
  SADDR: session address
  
  SID: session identifier,常用于连接其它列。
  
  SERIAL#: sid 会重用,但是同一个sid被重用时,serial#会增加,不会重复。
  
  AUDSID: audit session id。可以通过audsid查询当前session的sid。select sid from v$session where audsid=userenv('sessionid');
  
  PADDR: process address,关联v$process的addr字段,可以通过这个字段查处当前session对应操作系统的那个进程的id。
  
  USER#: session's user id。等于dba_users中的user_id。Oracle内部进程的user#为0。
  
  USERNAME: session's username。等于dba_users中的username。Oracle内部进程的username为空。
  
  COMMAND: session正在执行的SQL Id。1代表create table,3代表select。
  
  TADDR: 当前的transaction address。可以用来关联v$transaction的addr字段。
  
  LOCKWAIT: 可以通过这个字段查询出当前正在等待的锁的相关信息。sid & lockwait与v$lock中的sid & kaddr相对应。
  
  STATUS: 用来判断session状态。Active:正执行SQL语句。Inactive:等待操作。Killed:被标注为删除。
  
  SERVER: server type (dedicated or shared)
  
  SCHEMA#: schema user id。Oracle内部进程的schema#为0。
  
  SCHEMANAME: schema username。Oracle内部进程的schemaname为sys。
  
  OSUSER: 客户端操作系统用户名。
  
  PROCESS: 客户端process id。
  
  MACHINE: 客户端machine name。
  
  TERMINAL: 客户端执行的terminal name。
  
  PROGRAM: 客户端应用程序。比如ORACLE.EXE (PMON)或者sqlplus.exe
  
  TYPE: session type (background or user)
  
  SQL_ADDRESS, SQL_HASH_VALUE, SQL_ID, SQL_CHILD_NUMBER: session正在执行的sql statement,和v$sql中的address, hash_value, sql_id, child_number相对应。
  
  PREV_SQL_ADDR, PREV_HASH_VALUE, PREV_SQL_ID, PREV_CHILD_NUMBER: 上一次执行的sql statement。
  
  MODULE, MODULE_HASH, ACTION, ACTION_HASH, CLIENT_INFO: 应用通过DBMS_APPLICATION_INFO设置的一些信息。
  
  FIXED_TABLE_SEQUENCE: 当session完成一个user call后就会增加的一个数值,也就是说,如果session inactive,它就不会增加。因此可以根据此字段的值变化来监控某个时间点以来的session的性能情况。例如,一个小时以前,某个session的FIXED_TABLE_SEQUENCE是10000,而现在是20000,则表明一个小时内其user call比较频繁,可以重点关注此session的performance statistics。
  
  ROW_WAIT_OBJ#: 被锁定行所在table的object_id。和dba_objects中的object_id关联可以得到被锁定的table name。
  
  ROW_WAIT_FILE#: 被锁定行所在的datafile id。和v$datafile中的file#关联可以得到datafile name。
  
  ROW_WAIT_BLOCK#: Identifier for the block containing the row specified in ROW_WAIT_ROW#
  
  ROW_WAIT_ROW#: session当前正在等待的被锁定的行。
  
  LOGON_TIME: session logon time
  
  v$process
  
  ADDR: process address。可以和v$session的paddr字段关联。
  
  PID: Oracle进程identifier。
  
  SPID: 操作系统进程identifier。
  
  USERNAME: 操作系统进程的用户名。并非Oracle用户名。
  
  SERIAL#:: process serial number。
  
  TERMINAL: 操作系统terminal identifier(e.g., computer name)。
  
  PROGRAM: 进程正在执行的程序(e.g., ORACLE.EXE (ARC0)),和v$session中的program类似。
  
  BACKGROUND: 1代表oracle background process,null代表normal process。
  
  
  查看当前用户的sid和serial#:
  select sid, serial#, status from v$session where audsid=userenv('sessionid');
  
  查看当前用户的spid:
  select spid from v$process p, v$session s where s.audsid=userenv('sessionid') and s.paddr=p.addr;
  select spid from v$process p join v$session s on p.addr=s.paddr and s.audsid=userenv('sessionid');
  
  查看当前用户的trace file路径:
  select p.value || '\' || t.instance || '_ora_' || ltrim(to_char(p.spid,'fm99999')) || '.trc'
  from v$process p, v$session s, v$parameter p, v$thread t
  where p.addr = s.paddr and s.audsid = userenv('sessionid') and p.name = 'user_dump_dest';
  
  已知spid,查看当前正在执行或最近一次执行的语句:
  select /*+ ordered */ sql_text from v$sqltext sql
  where (sql.hash_value, sql.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 s where s.paddr = (select addr from v$process p where p.spid = to_number('&pid')))
  order by piece asc;
  
  查看锁和等待:
  col user_name format a10
  col owner format a10
  col object_name format a15
  col sid format 999999
  col serial# format 999999
  col spid format a6
  select /*+ rule */ lpad(' ', decode(l.xidusn, 0, 3, 0)) || l.oracle_username user_name,
  o.owner, o.object_name, o.object_type, 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
  order by o.object_id, xidusn desc;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-253704-1-1.html 上篇帖子: java操作Oracle数据库中的Clob,Blob字段 下篇帖子: java调用Oracle存储过程方法总结(转)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表