oracle手工生成AWR报告方法记录

摘要:
AWR(AutomaticWorkloadRepository)报告是我们进行日常数据库性能评估和发现SQL问题的重要手段。精通AWR报告是DBA开发、操作和维护的重要基本技能。AWR报告的原理基于Oracle数据库的定时镜像功能。默认情况下,Oracle数据库后台进程将以一定间隔(一小时)收集系统的当前状态映像,并将其保存在数据库中。生成AWR报告时,只需指定分析的时间段(开始镜像

AWR(Automatic Workload Repository)报告是我们进行日常数据库性能评定、问题SQL发现的重要手段。熟练掌握AWR报告,是做好开发、运维DBA工作的重要基本功。

 

 

AWR报告的原理是基于Oracle数据库的定时镜像功能。默认情况下,Oracle数据库后台进程会以一定间隔(一小时)收集系统当前状态镜像,并且保存在数据库中。生成AWR报告时,只需要指定进行分析的时间段(开始镜像编号和结束镜像编号),就可以生成该时间段的性能分析情况。AWR镜像保存在数据库中的时间为一个月左右。

 

 

目前Oracle10g之后,AWR报告取代了原先的Statspack报告成为一个主流性能分析报告。通常可以从OEM(Oracle Enterprise ManagerConsole)平台上生成查看AWR报告。在OEM中,使用图形化方法更加容易。本篇中介绍使用手工脚本方式生成AWR的方法,脱离OEM的限制。

 

 

1、 运行脚本

 

首先,准备一个目录作为AWR生成报告的路径。

 

 

[oracle@bspdev /]$ ls -l | greptest

drwxr-xr-x.  2oracle oinstall 4096 Jun 21 13:01test

 

[oracle@bspdev /]$ cdtest

 

 

启动sqlplus等开发工具,调用生成脚本。程序脚本一般保存在$ORACLE_HOME下的rdbms/admin中,名称为awrrpt.sql。

 

 

[oracle@bspdev test]$ sqlplus/nolog

 

SQL*Plus: Release11.2.0.1.0 Production onTue Jun 21 13:04:44 2011

 

Copyright (c) 1982, 2009,Oracle. Allrights reserved.

 

SQL> conn / as sysdba

Connected.

 

--调用脚本,生成文件

SQL>@?/rdbms/admin/awrrpt.sql

 

 

之后进入报告参数输入模块。

 

2、输入报告参数

 

之后,要持续输入一系列的报告参数。

 

ü       输入生成报告类型,目前AWR提供txt和html两种格式。需要确认生成格式,默认是html格式。

 

 

Current Instance

~~~~~~~~~~~~~~~~

 

  DBId   DBName     InstNum Instance

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

 4143510747 ORA11G             1ora11g

 

 

Specify the Report Type

~~~~~~~~~~~~~~~~~~~~~~~

Would you like an HTML report, or a plaintext report?

Enter 'html' for an HTMLreport, or 'text' for plain text

Defaults to'html'

 

 

ü       报告涉及天数范围

 

启动报告后,会显示生成实例的名称等基本信息。

 

默认情况下,AWR会将镜像信息保留一个月。手工生成的时候,需要确认生成AWR报告的时间范围。一般情况下,特别是生产环境下,我们通常设置1-7天也就够用了。

 

 

Instances in this Workload Repositoryschema

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

  DBId    InstNum DB Name     Instance    Host

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

* 4143510747       1ORA11G      ora11g      bspdev.local

                                               domain

 

Using 4143510747 for databaseId

Using         1for instance number

 

 

Specify the number of days of snapshots tochoose from

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Entering the number of days (n) will resultin the most recent

(n) days of snapshots beinglisted. Pressingwithout

specifying a number lists all completedsnapshots.

 

Enter value for num_days:3 

 

 

ü       输入开始和结束的snapshot编号

 

输入天数信息后,AWR生成代码会将天数范围内的snapshot镜像点列出,供输入选择。

 

 

Listing the last 3 days of CompletedSnapshots

 

                                                       Snap

Instance    DBName       SnapId   SnapStarted   Level

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

ora11g      ORA11G           178920 Jun 2011 13:01     1

                              179020 Jun 2011 14:00     1

                              179120 Jun 2011 15:00     1

                              179220 Jun 2011 16:00     1

                              (篇幅原因,有省略……

                              181121 Jun 2011 11:00     1

                              181221 Jun 2011 12:00     1

                              181321 Jun 2011 13:00     1

 

 

 

Specify the Begin and End SnapshotIds

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

 

之后,我们需要根据列出的时间范围,输入开始和结束的snap编号。

 

 

Specify the Begin and End SnapshotIds

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Enter value for begin_snap:1796

Begin Snapshot Id specified:1796

 

Enter value for end_snap:1813 

 

 

ü       确定报告名称

 

最后就是确定生成报告的名称。一般采用默认的名称就可以了。

 

 

Specify the Report Name

~~~~~~~~~~~~~~~~~~~~~~~

The default report file name isawrrpt_1_1796_1813.html. To use thisname,

press to continue, otherwise enter analternative.

 

Enter value forreport_name:

 

 

之后输出内容很多,此处不加以累述。最后提示报告生成成功。

 

 

Report written toawrrpt_1_1796_1813.html

 

 

于是,指定目录上可以看到相应的报告文件。

 

 

[oracle@bspdev test]$ ls-l

total 508

-rw-r--r--. 1 oracle oinstall 515262 Jun 2113:10 awrrpt_1_1796_1813.html

 

 

 

3、说明两个问题

 

首先,此处生成的html格式的报表。如果要求生成txt格式,就在生成过程中选择text格式报表。

 

 

Specify the Report Type

~~~~~~~~~~~~~~~~~~~~~~~

Would you like an HTML report, or a plaintext report?

Enter 'html' for an HTML report, or 'text'for plain text

Defaults to 'html'

Enter value for report_type:text

 

Type Specified: text

 

End of Report

Report written toawrrpt_1_1789_1800.txt

 

[oracle@bspdev test]$ ls-l

total 692

-rw-r--r--. 1 oracle oinstall 180601 Jun 2113:27 awrrpt_1_1789_1800.txt

-rw-r--r--. 1 oracle oinstall 515262 Jun 2113:10 awrrpt_1_1796_1813.html

 

 

 

第二个就是调用脚本的方式问题。调用时使用的sqlplus客户端可以在Oracle服务器本机上(远程登录),也可以在客户端机器本机上。笔者建议是在客户端本机上进行生成,这样可以避免报告文件来回拷贝的工作。但是最好要保证客户端版本与服务器版本相匹配。

 

 

4、结论

 

手工生成AWR报告,可以避免受到OEM的限制约束,而且灵活度高。本篇记录,权当备忘。

免责声明:文章转载自《oracle手工生成AWR报告方法记录》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇MySQL MySql连接数与线程池Selenium自动化工具工作原理下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

FastReport VCL4.9发布

FastReport VCL 4.9发布 磐岩科技——控件中国网(ComponentCN.com)核心合作伙伴俄罗斯FastReport公司近日宣布 FastReport VCL版报表控件产品发布V4.9版, FastReport VCL是一个非常著名的VCL报表控件,可以帮助您的应用程序快速高效地生成报表。 FastReport提供全面的报表开发工具,...

(appium+python)UI自动化_09_unittest批量运行测试用例&生成测试报告

前言 上篇文章【(appium+python)UI自动化_08_unittest编写测试用例】讲到如何使用unittets编写测试用例,并执行测试文件。接下来讲解下unittest如何批量执行测试文件并生成测试报告。 简单实例 实例讲解 一、 项目路径获取 project_name:项目名称,需更换为自己项目的名称 project_path:项目路径,获...

stimulsoft Report报表使用笔记

1.使用设计器设计mrt报表模板,或者从其他文件复制修改 2.删除business object 数据源 3.使用代码添加数据源 ParcelChangeItem change = new ParcelChangeItem(); string filename = @"D:workixxx信息.mrt"; Stimulsoft.Report.StiRe...

jmeter在linux机器上的安装和操作:

一、jmeter在linux机器上的安装:1、首先确定jmeter和JDK跟主机的版本一致 2、然后把JDK和Jmeter放在一个目录下,最好新建一个目录,分别存放 上传到目录rz jdk-8u74-linux-x64.gz3、然后各自解压【tar -zxvf jdk-8u74-linux-x64.gz】 4、解压完之后pwd出路径,然后再去配置环境变量...

【原创】大叔经验分享(21)yarn中查看每个应用实时占用的内存和cpu资源

在yarn中的application详情页面 http://resourcemanager/cluster/app/$applicationId 或者通过application命令 yarn application -status $applicationId 只能看到应用启动以来占用的资源*时间统计,比如: Aggregate Resource Allo...

pytest测试报告allure

1.python安装allure插件,pip install allure-pytest(PS:安装完成之后,打开一个你之前写的pytest脚本,看能不正常使用,如果报错:AttributeError: module 'allure' has no attribute 'severity_level'这个是之前 pytest-allure-adaptor...