oracle数据库mysql性能_oracle数据库性能分析

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

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

利用如下sql语句,将进程的进程号代替下面语句的PID:select sql_text,spid,v$session.program,process from v$sqlarea,v$session,v$processwhere v$sqlarea.address=v$session.sql_address and v$sqlarea.hash_value=v$session.sql_hash_value andv$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=用户名/密码

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值