我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何手工生成AWR运行期对比报告

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何手工生成AWR运行期对比报告

这篇文章将为大家详细讲解有关如何手工生成AWR运行期对比报告,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

 

AWR(Automatic Workload Repository)报告是Oracle 10g之后推出的重要性能诊断工具。AWR是作为Statspack报告的一种有力延伸。借助AWR,我们可以方便的对Oracle数据库的特定工作时间段进行性能分析评价,最终达到发现瓶颈调优的目标。

 

作为DBA,手工生成AWR报告是工作基本功之一。笔者在之前的《手工生成AWR报告记录》(http://space.itpub.net/17203031/viewspace-700471)中,就已经详细介绍过如何在sqlplus工具下生成AWR报告。

 

1、从AWR到AWR Compare Period Report

 

AWR是一个产品体系,根据定时收集的系统运行数据,我们其实可以做的更多。在现在主流的运维管理和调优过程中,基线baseline的概念是一直贯穿始终。系统运行负载Baseline、关键SQL执行计划Baseline等等,反复出现。总之,所谓的Baseline,简单的说就是一套运行负载指标或者执行计划指标。当你认为系统出现问题的时候,可以将Baseline作为标准进行对比,发现问题所在。进一步的,可以将Baseline作为应急手段,强制使用应对生产(SQL Profile、SPM)。

 

我们一般的调优过程中,也的确需要这样的小工具。比如:业务高峰期和低谷期,数据库各方面指标有什么样显著的差异?进行调优之后,系统性能指标有何种方式变化?这种时候,生成两份AWR,看着对比的确是一种方法。但是,Oracle已经为我们提供出AWR Compare Period Report来方便实现这样的功能。

 

从原理上,AWR Compare Period Report不难理解。Oracle将各个时间snap的性能数据保存在SYSAUX表空间的一系列数据字典表中,只要经过合理的组织,compare report不是一件困难的事情。

 

2、手工生成报告

 

本文是一篇记录文章,依然采用手工sqlplus的方法生成报告。

 

ü        登录sqlplus,运行脚本

 

使用sqlplus,登录入指定系统。

 

 

D:\>sqlplus /nolog

SQL*Plus: Release 11.2.0.1.0 Production on 星期一 3月 5 09:02:42 2012

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

 

SQL>(登录过程略……)

 

--调用脚本

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

 

 

注意:在sqlplus中,?表示$ORACLE_HOME路径。指定的awrddrpt.sql脚本,也是确实在客户端本地的SQL执行脚本。如果使用如PL/SQL Developer等开发工具,请指定直接路径。

 

ü        输入基本报告类型

 

首先同AWR报告一样, Compare Period Report也存在TEXT和HTML两种格式支持。在创建过程中,我们需要进行选定。

 

 

Current Instance

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

 

   DB Id       DB Id    DB Name      Inst Num Inst Num Instance

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

 2351142467  2351142467 NBSTEST             1        1 NBSTEST

 

Specify the Report Type

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

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'

输入 report_type 的值:

 

Type Specified:                  html

 

 

ü        输入第一对比时间段项目

 

既然要做到对比,首先需要指定一个对比时间范围。这个过程同一般AWR报告相同,过程不予累述。

 

 

Instances in this Workload Repository schema

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

 

   DB Id     Inst Num DB Name      Instance     Host

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

* 2351142467        1 NBSTEST      NBSTEST      P550_05_LC

 

Database Id and Instance Number for the First Pair of Snapshots

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

Using 2351142467 for Database Id for the first pair of snapshots

Using          1 for Instance Number for the first pair of snapshots

 

 

Specify the number of days of snapshots to choose from

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

Entering the number of days (n) will result in the most recent

(n) days of snapshots being listed.  Pressing <return> without

specifying a number lists all completed snapshots.

 

--输入对比时间范围

输入 num_days 的值:  3

 

 

之后,Oracle会列出三天范围的snap信息。

 

 

Listing the last 3 days of Completed Snapshots

                                                        Snap

Instance     DB Name        Snap Id    Snap Started    Level

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

NBSTEST      NBSTEST          10251 03 3月  2012 00:00     1

                              10252 03 3月  2012 01:00     1

(篇幅原因,省略部分……)

                              10305 05 3月  2012 06:00     1

 

                                                        Snap

Instance     DB Name        Snap Id    Snap Started    Level

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

NBSTEST      NBSTEST          10306 05 3月  2012 07:00     1

                              10307 05 3月  2012 08:00     1

                              10308 05 3月  2012 09:00     1

 

 

Specify the First Pair of Begin and End Snapshot Ids

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

输入 begin_snap 的值:

 

--指定时间片

Specify the First Pair of Begin and End Snapshot Ids

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

输入 begin_snap 的值:  10296

First Begin Snapshot Id specified: 10296

 

输入 end_snap 的值:  10298

 

 

设定了开始和结束时间snap,作为第一个时间。

 

ü        输入第二对比时间段项目

 

第二报告时间snap信息基本相同,不予累述。

 

 

Instances in this Workload Repository schema

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

   DB Id     Inst Num DB Name      Instance     Host

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

* 2351142467        1 NBSTEST      NBSTEST      P550_05_LC

 

Database Id and Instance Number for the Second Pair of Snapshots

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

Using 2351142467 for Database Id for the second pair of snapshots

Using          1 for Instance Number for the second pair of snapshots

 

Specify the number of days of snapshots to choose from

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

Entering the number of days (n) will result in the most recent

(n) days of snapshots being listed.  Pressing <return> without

specifying a number lists all completed snapshots.

 

输入 num_days2 的值:

 

输入 num_days2 的值:  1

 

Listing the last day's Completed Snapshots

                                                        Snap

Instance     DB Name        Snap Id    Snap Started    Level

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

NBSTEST      NBSTEST          10299 05 3月  2012 00:00     1

 (篇幅原因,省略……)

                              10306 05 3月  2012 07:00     1

                              10307 05 3月  2012 08:00     1

                              10308 05 3月  2012 09:00     1

 

 

 

Specify the Second Pair of Begin and End Snapshot Ids

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

输入 begin_snap2 的值:

--输入时间片

 

Specify the Second Pair of Begin and End Snapshot Ids

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

输入 begin_snap2 的值:  10306

Second Begin Snapshot Id specified: 10306

 

输入 end_snap2 的值:  10308

 

 

ü        指定生成报告名称,生成报告

 

 

Specify the Report Name

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

The default report file name is awrdiff_1_10296_1_10306.html  To use this name,

press <return> to continue, otherwise enter an alternative.

 

输入 report_name 的值: --使用默认名称,保持为空

Using the report name awrdiff_1_10296_1_10306.html

 

 

<br /><a class="awr" href="#top">Back to Top</a><p />

<p />

</body></html>

Report written to awrdiff_1_10296_1_10306.html

 

 

在目录上,我们就可以发现我们生成的报告文件。

 

 

3、报告内容粗览

 

与AWR报告不同,Compare Period Report强调对比。在所有的项目中,均以第一个和第二个进行对比,并且列出差异值。这对于我们进行负载对比等操作,有很多好处。

可以方便的让我们进行性能对比和调优前后对比。

 

4、结论

 

AWR报告以及其衍生产品,是我们进行性能调优、问题发现的重要工具武器。用好这些工具,是我们完成工作、履行责任和前进的重要前提。AWR Compare Period Report在进行基线对比和调优效果对比时,是非常方便的工具。

 

关于如何手工生成AWR运行期对比报告就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何手工生成AWR运行期对比报告

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何手工生成AWR运行期对比报告

这篇文章将为大家详细讲解有关如何手工生成AWR运行期对比报告,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 AWR(Automatic Workload Repository)报告是Orac
2023-06-06

如何生成Linux运行时间报告的Bash脚本

这篇文章主要介绍了如何生成Linux运行时间报告的Bash脚本,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。什么是 uptime 命令uptime 命令将告诉你系统已经运行了
2023-06-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录