当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle捕获问题SQL解决CPU过渡消耗

Oracle
理解SCN与TimeStamp的相互转换
用OMS来实现Oracle数据备份的方法
详细介绍Oracle数据库的启动和关闭
Oracle数据库重做日志文件丢失后的恢复
检测Oracle的可用性和表空间容量
oracle的long类型字段的应用
把数据从MySQL迁到Oracle的几点注意事项
没有Oracle客户端系统移植的三种方法
Oracle监听器服务不能启动的7步解决法
Oracle 10g的自动段空间管理(ASSM)
Oracle运行速度与效率高的秘密
Oracle实现自增型ID和删除重复记录
Oracle数据库存储过程的6个问题
Oracle 10G里手工建库的全过程
Oracle 10g手工创建数据库个人经验
redhat linux 下安装oracle 10g 的方法
Oracle静态注册和动态注册
Oracle数据更改后出错
JSP+Oracle简便通用的表单数据存储处理方法
Oracle 10g实用程序trcsess:跟踪sql语句

Oracle捕获问题SQL解决CPU过渡消耗


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 95 ::
收藏到网摘: n/a

正在看的ORACLE教程是:Oracle捕获问题SQL解决CPU过渡消耗。本文通过实际业务系统中调整的一个案例,试图给出一个常见CPU消耗问题的一个诊断方法.大多数情况下,系统的性能问题都是由不良SQL代码引起的,那么作为DBA,怎样发现和解决这些SQL问题就显得尤为重要.
  本案例平台为UNIX,所以不可避免的应用了一些Unix下常用的工具.如vmstat,top等.
  本文适宜读者范围:中高级.
  系统环境:
   OS: Solaris8
   Oracle: 8.1.7.4
  问题描述:
  开发人员报告系统运行缓慢,已经影响业务系统正常使用.请求协助诊断.
  1.登陆数据库主机
  使用vmstat检查,发现CPU资源已经耗尽,大量任务位于运行队列:

  2.使用Top命令
  观察进程CPU耗用,发现没有明显过高CPU使用的进程

  3.检查进程数量

  发现系统存在大量Oracle进程,大约在300左右,大量进程消耗了几乎所有CPU资源,而正常情况下Oracle连接数应该在100左右.

--------------------------------------------------------------------------------