oracle数据库性能分析

平时要注意监控数据库,防止数据库产生严重的性能问题。当数据库出现性能问题时,要积极去解决它,防止出现数据丢失、生产库死机等严重事件。监控数据库手段有多种,比如利用系统命令prstatvmstat等去监控系统资源的使用情况;利用telnet命令登陆中心数据库观察服务器cpuI/O是否出现异常;利用数据库视图v$session等观察数据库的连接是否处于正常状态;利用spotlightstaspack工具获取数据库实时运行情况等等。

     telnet登陆数据库,利用prstat –a来查看系统进程情况。

利用如下sql语句,将进程的进程号代替下面语句的PID
select sql_text,spid,v$session.program,process from v$sqlarea,v$session,v$process
  
where v$sqlarea.address=v$session.sql_address and v$sqlarea.hash_value=v$session.sql_hash_value and  
v$session.paddr=v$process.addr and v$process.spid in (PID);

查找出此进程正在运行的sql语句

  查找出此进程对应的数据库会话,利用命令:

select a.* from v$session a,v$process b where a.paddr=b.addr and b.spid=PID;

然后,可以跟踪此会话,获取sql语句的资源耗费情况以及执行计划,也可重开会话,执行之,获取跟踪文件。

 

 Oracle数据库提供了针对会话生成sql跟踪文件的功能,以便查看会话的sql执行过程,找出影响系统性能的问题所在,提供了一种调整Oracle性能的行之有效的工具。

    一  跟踪当前进程:

        1.查看初始化参数TIMED_STATISTICS的取值,将其设置为true.

        2.查看user_dump_dest的取值,确定跟踪文件的存放位置。如有必要,限制max_dump_file_size的取值

        3.启用当前session跟踪:alter session set sql_trace=true;

        4.运行系统,以便收集数据

        5.结束跟踪:alter session set sql_trace=false;

        6.利用tkprof工具格式化生成的跟踪文件,研究之,找问题,解决问题,提高系统性能。

    二  跟踪客户进程:

        1.识别要跟踪的客户进程到数据库的连接,这方面sql语句很多:

          select s.sid sid, s.SERIAL# "serial#", s.username, s.machine, s.program,
          p.spid ServPID, s.server
          from v$session s, v$process p
          where p.addr = s.paddr ;

         2.设置相应参数:exec sys.dbms_system.set_bool_param_in_session(sid,serial#,'timed_statistics',true);

                         exec sys.dbms_system.set_int_param_in_session(sid,serial#,'max_dump_file_size',最大文件的大小); 

            查看user_dump_dest,确定跟踪文件的位置。     

         3.启动跟踪功能:exec sys.dbms_system.set_sql_trace_in_session(sid,serial#, true);

         4.让系统运行一段时间,以便可以收集到跟踪数据

         5.关闭跟踪功能:exec sys.dbms_system.set_sql_trace_in_session(sid,serial#, false);

         6.利用tkprof工具格式化生成的跟踪文件,研究之,找问题,解决问题,提高系统性能。

 

tkprof基本用法:

tkprof   ...trc  ....out   sys=no  explain=用户名/密码

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22295535/viewspace-710159/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22295535/viewspace-710159/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值