shell指令碼實現自動生成awr報告
主要實現自動生成awr報告,程式碼思想非本人,但是有進行部分改造,之前網上的不能執行,經過部分改造可以正常執行的
生成語法
[oracle@hxy ~]$ bash ./dba_oracle_awr.sh -s HXY -f 20131125140000 -t 20131125150000 -p text -h /u01/app/oracle/product/10.2.1/db_1
指令碼如下
[oracle@hxy ~]$ cat dba_oracle_awr.sh
#!/usr/bin/bash
# ********************************
# * dba_oracle_awr.sh
# ********************************
# Usage: dba_oracle_awr.sh -s [instance_name]
# -f [from time]
# -t [to time]
# -p [report type, html or text]
# -h [oracle home]
# -n [tns admin]
#
# time format: 'yyyymmddhh24miss'.
# E.g 201311251300 means 05:00:00pm, oct 04, 2013
#
#
# **********************
# get parameters
# **********************
while getopts ":s:f:t:p:h:n" opt
do
case $opt in
s) instance=$OPTARG
;;
f) from=$OPTARG
;;
t) to=$OPTARG
;;
p) type=$OPTARG
type=$(echo $type|tr "[:upper:]" "[:lower:]")
;;
h) oracle_home=$OPTARG
;;
n) tns_admin=$OPTARG
;;
'?') echo "$0: invalid option -$OPTARG">&2
exit 1
;;
esac
done
if [ "$instance" = "" ]
then
echo "instance name(-s) needed"
echo "program exiting..."
exit 1
fi
if [ "$from" = "" ]
then
echo "from time (-f} needed"
echo "program exiting..."
exit 1
fi
if [ "$to" = "" ]
then
echo "to time (-t) needed"
echo "program exiting..."
exit 1
fi
if [ "${oracle_home}" = "" ]
then
echo "oracle home (-h) needed"
echo "program exiting..."
exit 1
fi
sqlplus="${oracle_home}/bin/sqlplus"
echo $sqlplus
if [ "$type" = "" ]
then
type="html"
fi
# ********************
# trim function
# ********************
function trim()
{
local result
result=`echo $1|sed 's/^ *//g' | sed 's/ *$//g'`
echo $result
}
# *******************************
# get begin and end snapshot ID
# *******************************
define_dur()
{
begin_id=`$sqlplus -s /nolog<
set pages 0
set head off
set feed off
select max(SNAP_ID) from DBA_HIST_SNAPSHOT where
BEGIN_INTERVAL_TIME<=to_date($from,'yyyymmddhh24miss');
EOF`
ret_code=$?
if [ "$ret_code" != "0" ]
then
echo "sqlplus failed with code $ret_code"
echo "program exiting..."
exit 10
fi
end_id=`$sqlplus -s /nolog<
set pages 0
set head off
set feed off
select min(SNAP_ID) from DBA_HIST_SNAPSHOT where
END_INTERVAL_TIME>=to_date($to,'yyyymmddhh24miss');
spool off
EOF`
ret_code=$?
if [ "$ret_code" != "0" ]
then
echo "sqlplus failed with code $ret_code"
echo "program exiting..."
exit 10
fi
begin_id=$(trim ${begin_id})
end_id=$(trim ${end_id})
# echo "begin_id: $begin_id end_id: $end_id"
}
# *******************************
# generate AWR report
# *******************************
generate_awr()
{
awrsql="${oracle_home}/rdbms/admin/awrrpt.sql"
if [ ! -e $awrsql ]
then
echo "awrrpt.sql does not exist, exiting..."
exit 20
fi
tmp1_id=${begin_id}
#echo "begin_id is: $begin_id"
#echo "tmp1_id is: $tmp1_id"
while [[ ${tmp1_id} -lt ${end_id} ]]
do
let tmp2_id=${tmp1_id}+1
if [ $type == "text" ]
then
report_name="awrrpt_${instance}_${tmp1_id}_${tmp2_id}.txt"
else
report_name="awrrpt_${instance}_${tmp1_id}_${tmp2_id}.html"
fi
#echo $report_name
$sqlplus -s "/ as sysdba">/dev/null<
define report_type=$type
define num_days=1
define begin_snap=${tmp1_id}
define end_snap=${tmp2_id}
define report_name=${report_name}
@${oracle_home}/rdbms/admin/awrrpt.sql
exit;
EOF
tmp1_id=${tmp2_id}
done
}
# *******************************
# main routing
# *******************************
#read_act
define_dur
generate_awr
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/17172228/viewspace-1062096/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- awr報告每天自動生成指令碼指令碼
- 【AWR】Oracle批量生成awr報告指令碼Oracle指令碼
- Shell指令碼實現生成SSL自簽署證書指令碼
- [shell]shell指令碼實現每天自動抽取資料插入hive表指令碼Hive
- linux透過shell指令碼實現ssh互動式自動化Linux指令碼
- 自動批次實現linux機器ssh免密shell指令碼Linux指令碼
- 【Linux】【Shell】主控指令碼實現Linux指令碼
- 實現指令碼自動部署docker指令碼Docker
- Oracle生成awr報告操作步驟Oracle
- 自動化指令碼安裝mysql shell指令碼範例指令碼MySql
- python實現自動搶課指令碼Python指令碼
- shell指令碼實現DNS正向解析指令碼DNS
- shell 備份檔案指令碼+自動清理指令碼
- SQL Server映象自動生成指令碼方法SQLServer指令碼
- Shell指令碼實現Twitter的Snowflake演算法的ID生成器指令碼演算法
- shell指令碼實現多臺伺服器自動巡檢--可參考學習指令碼伺服器
- 案例八:Shell自動化管理賬號指令碼指令碼
- shell指令碼報錯:[: missing `]‘指令碼
- 如何讓shell指令碼自殺指令碼
- 案例四:Shell指令碼生成隨機密碼指令碼隨機密碼
- 利用Python實現自動掃雷小指令碼Python指令碼
- flyway實現java 自動升級SQL指令碼JavaSQL指令碼
- shell指令碼實現---Zabbix5.0快速部署指令碼
- shell指令碼-免互動指令碼
- 本機生成遠端資料庫AWR報告資料庫
- Mybatis自動程式碼生成器的實現MyBatis
- Shell指令碼最佳實踐指令碼
- 用bat指令碼自動生成安裝包InnosetupBAT指令碼
- 使用 Fastlane 實現 iOS 跟 Android 自動打包指令碼ASTiOSAndroid指令碼
- 實現MySQL表結構自動分割槽指令碼MySql指令碼
- 9個實用shell指令碼指令碼
- 生成 Linux 執行時間報告的 Bash 指令碼Linux指令碼
- shell指令碼指令碼
- [20231023]生成bbed的執行指令碼(bash shell).txt指令碼
- 如何在12.2版本ADG備庫生成AWR報告
- 達夢資料庫如何來配置並生成AWR報告資料庫
- 自動定時備份 mysql 資料庫 的 shell 指令碼MySql資料庫指令碼
- 用於自動監控磁碟使用情況的 Shell 指令碼指令碼
- 自動輸入密碼使用root許可權開啟shell指令碼密碼指令碼