Oracle优化CPU的使用率的具体表现

数据库 Oracle
以下的文章主要是对Oracle优化CPU的使用率详解,其中包括如何查看Oracle优化CPU的使用率 ,以及查看相关数据库使用CPU的时间的实际操介绍。

我个人对Oracle很是喜欢,同时在实际工作中也十分喜欢Oracle优化CPU的使用率的相关经验教训,以下就是以这个问题来详细说说吧。CPU是服务器的一项重要资源,服务器良好的工作状态是在工作高峰时CPU的使用率在90%以上。

如果空闲时间Oracle优化CPU使用率就在90%以上,说明服务器缺乏CPU资源;如果工作高峰时Oracle优化CPU使用率仍然很低,说明服务器CPU资源还比较富余。

查看Oracle优化CPU使用率

使用操作相同命令可以看到CPU的使用情况,一般Unix操作系统的服务器,可以使用“sar u”命令查看Oracle优化CPU使用率,Windows NT操作系统的服务器,可以使用性能管理器来查看CPU的使用率。

查看数据库使用CPU的时间

可以通过查看V$SYSSTAT数据字典中b“CPU used by this session”统计项得知Oracle数据库使用的CPU时间,查看“OS User level CPU time”统计项得知操作系统的用户态下CPU时间,查看“OS System call CPU time”统计项得知操作系统的系统态下CPU时间,操作系统总的CPU时间就是用户态和系统态时间之和。

如果Oracle数据库使用的CPU时间占操作系统总的CPU时间90%以上,说明服务器CPU基本上被Oracle数据库使用着。反之,则说明服务器CPU被其它程序占用过多,Oracle数据库无法得到更多的CPU时间。

数据库管理员还可以通过查看V$SYSSTAT数据字典来获得当前连接Oracle数据库各个会话占用的CPU时间,从而得知什么会话耗用服务器CPU比较多。出现CPU资源不足的情况是很多的,SQL语句的重解析、低效率的SQL语句、锁冲突都会引起CPU资源不足。

查看SQL语句的解析情况

数据库管理员可以执行下述语句来查看SQL语句的解析情况:

 

  1. SELECT * FROM V$SYSSTAT  
  2. WHERE NAME IN  
  3. ('parse time cpu', 'parse time elapsed', 'parse count (hard)');  

 

这里“parse time cpu”是系统服务时间,“parse time elapsed”是响应时间,用户等待时间waite time = parse time elapsed - parse time cpu。

由此可以得到用户SQL语句平均解析等待时间=waite time / parse count。这个平均等待时间应该接近于0,如果平均解析等待时间过长,数据库管理员可以通过下述语句来发现是什么SQL语句解析效率比较低。

 

  1. SELECT SQL_TEXT, PARSE_CALLS, EXECUTIONS FROM V$SQLAREA  
  2. ORDER BY PARSE_CALLS;  

 

程序员可以优化这些语句,或者增加Oracle参数SESSION_CACHED_CURSORS的值。以上介绍Oracle优化CPU使用率。

【编辑推荐】

  1. 对Oracle SQL到DB2 SQL移植的浅析
  2. Oracle 数据库的SQL的描述
  3. Oracle数据字典的实操
  4. Oracle数据库里重复没有用的数据如何删除
  5. Oracle 多表关联如何更新多个字段


 

责任编辑:佚名 来源: 博客园
相关推荐

2010-03-29 12:54:45

Oracle spat

2021-02-02 09:00:19

PaaS云计算平台即服务

2010-03-12 10:30:18

Python语言

2010-08-06 10:29:01

IBM DB2数据移

2009-11-16 17:03:20

Oracle优化CPU

2010-04-27 10:32:54

Oracle优化CPU

2019-01-15 15:04:54

CPU电脑使用率

2021-08-10 11:45:57

topCPULinux

2021-05-31 15:53:57

CPU Top命令

2024-04-11 13:27:19

Linuxtop命令

2022-03-02 09:01:07

CPU使用率优化

2010-03-29 10:55:38

Oracle优化

2010-04-20 14:18:23

2022-04-26 16:09:27

物联网智慧农业

2010-07-06 11:26:51

IPv6

2020-06-11 14:20:14

Go服务CPU

2014-12-01 13:44:03

cgroupscpulimitlinux

2010-05-05 18:01:29

Oracle时间

2010-04-07 14:34:11

2022-07-23 21:31:24

KubernetesLinux开源
点赞
收藏

51CTO技术栈公众号