使用shell脚本查看数据库负载情况(第二篇)

在之前写了一个shell脚本,能够得到一个基于时间点的数据库负载报告。
使用shell脚本查看数据库负载情况 http://blog.itpub.net/23718752/viewspace-1168027/

在生产环境中快照的生成频率可能10分钟或者半个小时就会生成,频率要快些,使用原先的脚本执行起来会有一定的延时。
想查看在快照的时间间隔内数据库的负载情况。这样能够更高效的定位某个问题。比如10点到11点,每10分钟生成一次快照。可能问题发生在10:40~10:50,如果通过一个小时的快照就不一定能够准确的定位问题。
我尝试了如下的脚本,能够很清晰地 列出快照信息和数据库的负载情况。

sqlplus -s $DB_CONN_STR@$SH_DB_SID
break on db_name
set pages 50
set linesize 100
prompt
prompt Current Instance
prompt ~~~~~~~~~~~~~~~~
select d.dbid            dbid
     , d.name            db_name
     , i.instance_number inst_num
     , i.instance_name   inst_name
  from v\$database d,
       v\$instance i;
select 
db_name
,begin_snap
,end_snap
,snapdate
,lvl
,round(((END_INTERVAL_TIME+0)-(BEGIN_INTERVAL_TIME+0 ))*24*60) duration_mins
,round((select round((sum(e.value) -
                        sum(b.value)) / 1000000 /60,2) dbtime
                        FROM DBA_HIST_SYS_TIME_MODEL e, DBA_HIST_SYS_TIME_MODEL b
                        WHERE
                         e.STAT_NAME = 'DB time'
                         and b.snap_id=begin_snap
                        and e.snap_id =end_snap
                        AND b.STAT_NAME = 'DB time'
                        group by e.snap_id,b.snap_id)) dbtime
from
(       
select 
      di.db_name                                        db_name
     , s.snap_id                                         begin_snap
     ,lead(s.snap_id ,1,s.snap_id ) over(order by s.end_interval_time ) end_snap
     , to_char(s.end_interval_time,'dd Mon YYYY HH24:mi') snapdate
     , s.snap_level                                      lvl     
     ,s.end_interval_time
     ,s.begin_interval_time
  from dba_hist_snapshot s
     , dba_hist_database_instance di
 where 
  ( di.dbid,di.instance_number) in
 (select d.dbid            dbid
     , i.instance_number inst_num
  from v\$database d,
       v\$instance i)
   and di.dbid             = s.dbid
   and di.instance_number  = s.instance_number
   and di.startup_time     = s.startup_time
   and to_char(END_INTERVAL_TIME,'yyyymmdd')='$1'
   and EXTRACT(HOUR FROM END_INTERVAL_TIME) between $2-1 and $3+1 
 order by db_name, instance_name, snap_id
 );  
EOF 

脚本的执行情况如下,生成的快照信息会前后顺延一个小时,比如查看10点到11点的信息,会列出9点到12点的信息。

> ksh showsnap2.sh 20141222 10 11
Current Instance
~~~~~~~~~~~~~~~~
      DBID DB_NAME     INST_NUM INST_NAME
---------- --------- ---------- ----------------
3100077577 XXXXXX             1 XXXXXX
DB_NAME   BEGIN_SNAP   END_SNAP SNAPDATE                 LVL DURATION_MINS     DBTIME
--------- ---------- ---------- ----------------- ---------- ------------- ----------
XXXXXX         24597      24598 22 Dec 2014 09:00          1            10        374
               24598      24599 22 Dec 2014 09:10          1            10        180
               24599      24600 22 Dec 2014 09:20          1            10        193
               24600      24601 22 Dec 2014 09:30          1            10        114
               24601      24602 22 Dec 2014 09:40          1             9        156
               24602      24603 22 Dec 2014 09:50          1            10        171
               24603      24604 22 Dec 2014 10:00          1            10        220
               24604      24605 22 Dec 2014 10:10          1            10        214
               24605      24606 22 Dec 2014 10:20          1            10        256
               24606      24607 22 Dec 2014 10:30          1            10        270
               24607      24608 22 Dec 2014 10:40          1            10       1288
               24608      24609 22 Dec 2014 10:50          1            10        346
               24609      24610 22 Dec 2014 11:00          1            10        350
               24610      24611 22 Dec 2014 11:10          1            10        398
               24611      24612 22 Dec 2014 11:20          1            10        355
               24612      24613 22 Dec 2014 11:30          1            10        295
               24613      24614 22 Dec 2014 11:40          1            10        318
               24614      24615 22 Dec 2014 11:50          1            10        338
               24615      24616 22 Dec 2014 12:00          1            10        355
               24616      24617 22 Dec 2014 12:10          1            10        288
               24617      24618 22 Dec 2014 12:20          1            10        257
               24618      24619 22 Dec 2014 12:30          1            10        255
               24619      24620 22 Dec 2014 12:40          1            10        255
               24620      24620 22 Dec 2014 12:50          1            10          0
可以很清晰的看到在10:40~10:550的时候,负载异常的高,可以针对这种情况抓取一个awr报告来详细的分析一下。

时间: 2024-08-01 08:50:27

使用shell脚本查看数据库负载情况(第二篇)的相关文章

使用shell脚本查看数据库负载情况

平时在查看数据库的问题时,会有种迷茫的感觉,如果没有任何人反馈问题,基本上没有主动查找问题的方向,awr,ash都是在得知问题发生的时间段或者一些时间戳来从历史记录中查找相关的信息,个人整理了如下的脚本,能够显示当天的时间段内数据库的负载信息,能够很好掌握数据库的忙闲情况. 来看一个简单的例子,比如我要查看早上6点到中午12点数据库的负载情况 脚本 showdbtime.sh 显示的是在制定的时间段内的 数据库负载的一个综合值.比如6点到7点个小时(60分钟),dbtime如果是120分钟,那么

通过shell脚本查看数据库表空间使用情况

对于数据库中表空间查看,想必大家都有很多的脚本已经在用了,自己也啰嗦一下,分享一个通过shell脚本查看表空间使用情况的例子. 脚本如下: sqlplus -s $DB_CONN_STR@$SH_DB_SID   set echo off heading on underline on; column inst_num  heading "Inst Num"  new_value inst_num  format 99999; column inst_name heading &quo

shell脚本监控系统负载、CPU和内存使用情况_linux shell

在没有nagios监控软件的情况下,只要服务器能上互联网,就可通过发邮件的方式来提醒管理员系统负载与CPU占用的使用情况. 一.安装linux下面的一个邮件客户端msmtp软件(类似于一个foxmail的工具)  1.下载安装:  http://downloads.sourceforge.net/msmtp/msmtp-1.4.16.tar.bz2?modtime=1217206451&big_mirror=0 复制代码 代码如下: # tar jxvf msmtp-1.4.16.tar.bz2

怎么用shell脚本遍历数据库某个表,一个字段下的所有内容

问题描述 怎么用shell脚本遍历数据库某个表,一个字段下的所有内容 数据库为mysql 就是遍历一列上所有的内容,然后判断是否等于某个值,取出这个字段对应的其他字段的值. 解决方案 听你的意思应该就是: select * from 表名 where 列名=某个值; 解决方案二: 直接用sql语句来遍历判断条件查询数据好了

Linux Shell脚本查看NUMA信息

  这篇文章主要介绍了Linux Shell脚本查看NUMA信息,本文直接给出脚本实现代码,需要的朋友可以参考下 Nova在NFV场景下会提供NUMA相关高级特性,这里提供一个脚本查看计算节点的NUMA相关信息. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50

通过shell脚本查看package的信息

有时候想查看一个package的信息,但是对于package的名字不是很确定,比如只知道一个大概,知道一些关键字,这个时候通过图形工具是查找不到package的信息的,而且对于package的信息,我只关心package里面有哪些存储过程,哪些函数等,看看简单的参数情况就可以了,类似sqlplus的desc的形式. shell脚本的实现如下, 以下的脚本是查看是否有对应的package信息. PROC_OWNER=`sqlplus -silent $DB_CONN_STR@$SH_DB_SID

Linux Shell脚本查看NUMA信息_linux shell

Nova在NFV场景下会提供NUMA相关高级特性,这里提供一个脚本查看计算节点的NUMA相关信息. #!/bin/bash function get_nr_processor() { grep '^processor' /proc/cpuinfo | wc -l } function get_nr_socket() { grep 'physical id' /proc/cpuinfo | awk -F: '{ print $2 | "sort -un"}' | wc -l } func

通过shell脚本查看procedure的信息

在一个schema中,可能含有大量的procedure, 有时候想查看具体的信息,一般得通过toad,plsql dev等工具来查看,有时候在尽可能摆脱图形工具的前提下,想能够尽快的查找一些信息,还是使用shell脚本更快,更准,更直接. 可以使用如下的shell脚本来查找procedure的信息. 以下的脚本可以查找是否有需要的prcedure信息. PROC_OWNER=`sqlplus -silent $DB_CONN_STR@$SH_DB_SID set pagesize 40 feed

如何编写一个shell脚本查看某个进程是否在运行

问题描述 我需要做一个shell脚本,运行在Linux上,检查某个进程是否在运行,如果在运行则返回1,不在运行则返回0,在下对shell脚本不是很熟,请大家帮忙解决一下,谢谢啦-- ps:进程名称不能写死,应该是执行命令是传入的参数 解决方案 #!/bin/bashPROC_NAME=$1ProcNumber=`ps -ef |grep $PROC_NAME|grep -v grep|wc -l`if [ $ProcNumber -le 0 ];then result=0else result=