平时要注意监控数据库,防止数据库产生严重的性能问题。当数据库出现性能问题时,要积极去解决它,防止出现数据丢失、生产库死机等严重事件。监控数据库手段有多种,比如利用系统命令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=用户名/密码