怎样系统全面的分析oracle的AWR报告
系统全面的分析oracle的AWR报告的步骤:1、确定数据库类型;2、分析时间指标;3、整体认识;4、结合Time Model Statistics等。确定数据库类型是指在分析awr报告之前,首先要确定我们的数据库系统是oltp还是olap数据库。
在分析awr报告之前,首先要确定我们的系统是属于oltp(联机事务处理)还是olap(联机分析处理)数据库。对于不同的数据库系统,性能指标的侧重点是不一样的,比如,library hit和buffer hit,在olap系统中几乎可以忽略这俩个性能指标,而在oltp系统中,这俩个指标就非常关键了。
为了对数据库有个整体的认识,先看下面的性能指标:
可以看出,在整个sql执行时间(sql execute elapsed time)时间为5552019秒中,解析时间(parse time elapsed)用了36秒,硬解析时间(hard parse elapsed time)用了34秒。虽然硬解析时间占了整个解析时间的绝大部分,但解析时间是花的很少的,所以可以判断出,sql的解析没有成为性能的瓶颈,进一步推测,sql在获取数据的过程中遇到了瓶颈。
buffer busy waits 说明在获取数据的过程中,频繁的产生等待事件,很有可能产生了热点块,也就是说,很多会话都去读取同样的数据块,这一事件等待了5627394次,总共等待了5322924秒,平均等待时间为946毫秒,而且频率也是较高的,有95.9%,等待类别是并发。这里有一个概念:oracle操作的最小单位是块,当一个会话要修改这个块中的一条记录,会读取整个块,如果另一个会话要修改的数据也正好在这个块中,虽然这两个会话修改的记录不一样,也会产生等待direct path write temp和direct path read temp 说明用到了临时表空间,那我们再看一下Tablespace IO Stats:
各项指标都是非常高的,再根据上面的In-memory Sort是100%,没有产生磁盘排序,也就在排序的时候没有用到临时表空间,进一步推测,多个session,每个session执行的sql语句中多表关联,产生了很多中间数据,pga内存中放不下,用到了临时表空间,也有可能是用到了lob字段,在用lob字段的时候,也会用到临时表。
根据buffer busy waits等待次数,时间,频率都是较高的,我们重点看逻辑读,物理读,和执行时间最长的sql,把排在前几位的拿出来优化。优化的原则为降低物理读,逻辑读,sql语句中的子操作执行次数尽量少,在看oracle估计出来的执行计划是看不出子操作的执行次数的,要看运行时的执行计划。
Segment Statistics列出了用到的索引和表的使用情况,从这里也能看出索引和表的使用频率。Load Profile里面列出了每秒,每个事务所产生的日志,逻辑读和物理读等指标。
使用oralce用户登陆操作系统,如果不知道oracle用户密码,可从root用户 su – oracle:
server01:root:/>whoami
root
server01:root:/>su - oracle
server01:oracle:/home/oracle>whoami
oracle
server01:oracle:/home/oracle>
在oracle用户下执行 sqlplus / as sysdba命令,连接到oracle数据库:
server01:oracle:/home/oracle>sqlplus / as sysdba
SQL*Plus: Release 11.2.0.4.0 Production on Thu Dec 12 00:01:02 2019
Copyright (c) 1982, 2013, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL>
在sqlplus中执行 @?/rdbms/admin/awrrpt.sql:
SQL> @?/rdbms/admin/awrrpt.sql
Current Instance
~~~~~~~~~~~~~~~~
DB Id DB Name Inst Num Instance
----------- ------------ -------- ------------
919662622 DEVDB 1 devdb
Specify the Report Type
~~~~~~~~~~~~~~~~~~~~~~~
在执行@?/rdbms/admin/awrrpt.sql命令后,会提示输入导出报告的格式,默认格式为html,如果想导出html格式,直接Enter即可:
Would you like an HTML report, or a plain text report?
Enter 'html' for an HTML report, or 'text' for plain text
Defaults to 'html'
Enter value for report_type:
在输入要导出的天数之后,oracle会列出所有满足预期天数的snap的信息,根据需要,输入snap的开始ID:
Listing the last 2 days of Completed Snapshots
Instance DB Name Snap Id Snap Started Snap Level
------------ --------- --------- ------------------ -----
devdb DEVDB 3151 11 Dec 2019 00:00 1
3152 11 Dec 2019 01:00 1
3153 11 Dec 2019 02:00 1
3154 11 Dec 2019 03:00 1
3155 11 Dec 2019 04:00 1
3156 11 Dec 2019 05:00 1
3157 11 Dec 2019 06:00 1
3158 11 Dec 2019 07:00 1
3159 11 Dec 2019 08:00 1
3160 11 Dec 2019 09:00 1
3161 11 Dec 2019 10:00 1
3162 11 Dec 2019 11:00 1
3163 11 Dec 2019 12:00 1
3164 11 Dec 2019 13:00 1
3165 11 Dec 2019 14:00 1
3166 11 Dec 2019 15:00 1
3167 11 Dec 2019 16:00 1
3168 11 Dec 2019 17:00 1
3169 11 Dec 2019 18:00 1
3170 11 Dec 2019 19:00 1
3171 11 Dec 2019 20:00 1
3172 11 Dec 2019 21:00 1
3173 11 Dec 2019 22:00 1
3174 11 Dec 2019 23:00 1
3175 12 Dec 2019 00:00 1
Specify the Begin and End Snapshot Ids
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter value for begin_snap:
输入开始ID之后,会提示输入截止ID,根据需要输入截止ID:
Enter value for end_snap:
导出报告时,如果需要设置导出的报告名称,可根据提示进行修改:
Specify the Report Name
~~~~~~~~~~~~~~~~~~~~~~~
The default report file name is awrrpt_1_3151_3175.html. To use this name,
press <return> to continue, otherwise enter an alternative.
Enter value for report_name:
输入报告名称之后并敲击回车之后,oracle会自动生成AWR报告,可退出sqlplus进行查看:
SQL> exit
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
server01:oracle:/home/oracle>ls -lrt
total 12544
drwxr-xr-x 4 root system 256 Jul 02 1972 app
-rw-r--r-- 1 oracle dba 25178 Jul 02 1972 db.rsp
-rw-r--r-- 1 oracle dba 8 Jul 03 1972 #UNTITLED#
-rw-r----- 1 oracle dba 4950061 Jul 06 1972 core
-rw-r----- 1 oracle dba 289692 Jul 29 22:31 install2019-07-29_22-17-53.log
drwxr-xr-x 2 oracle dba 256 Aug 01 00:40 scripts
-rw-r--r-- 1 oracle dba 594527 Dec 11 22:37 test.html
-rw-r--r-- 1 oracle dba 545490 Dec 12 00:51 awr.html
延伸阅读1:AWR报告简介
AWR(Automatic Workload Repository)是自动负载信息库的英文缩写,AWR报告是Oracle 10g以后版本提供的一种性能收集和分析工具,能提供一个时间段内整个系统资源使用情况的报告,通过报告可以了解一个系统的整个运行情况。
最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台:织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。
相关文章推荐
立即开启你的数字化管理
用心为每一位用户提供专业的数字化解决方案及业务咨询