使用shell自動傳送Oracle AWR報告
1 需求
每天定時傳送重要的資料庫AWR到DBA郵件中,DBA接收到AWR郵件之後簡單檢視資料庫是否有異常等待事情和異常SQL,儘量避免等使用者發現資料庫慢時再去分析相關SQL
2 相關環境
作業系統
本指令碼是放在Red Hat下面執行,其它作業系統上面執行還未測試,因為使用的是dbms_workload_repository生成報表,所以可以分析任何作業系統下面的資料庫,也就是說和資料庫的作業系統沒有關係
資料庫版本
本指令碼可以分析Oracle 10g ,11g任何子版本資料庫
3 指令碼詳細介紹
指令碼存放目錄和檔案
[oracle@svr7-71 awrrpt]$ pwd
/home/oracle/awrrpt
[oracle@svr7-71 awrrpt]$ ls -lrt
-rwxrwx--- 1 oracle oinstall 1968 May 24 11:05 awrrpt.sh
drwxr-xr-x 2 oracle oinstall 4096 May 24 11:09 reports
-rwxrwx--- 1 oracle oinstall 360 May 24 11:52 run.sh
其中awrrpt.sh為生成AWR的指令碼,reports為存放生成後的AWR報告的資料夾
,run.sh為生成AWR的入口可以配置多個資料庫
[oracle@svr7-71 awrrpt]$ more awrrpt.sh
#!/bin/bash
# $1 startTime
# $2 endTime
# $3 TNS user/passpassword@sid
# creater: eymit.wu
# last modified: 2012-05-23
. ~/.bash_profile
PROJECT_HOME='/home/oracle/awrrpt'
REPORT_HOME='/home/oracle/awrrpt/reports'
TODAY=`date +%Y%m%d`
cd ${PROJECT_HOME}
INSTANCE_NAME=`sqlplus -s "$3" <set term off
set echo off
set pages 0
set heading off
select instance_name from v\\$instance;
exit;
EOF`
FILE_NAME=`sqlplus -s "$3" <
set term off
set echo off
set pages 0
set heading off
select '${REPORT_HOME}/awrrpt_' || to_char(sysdate, 'yyyymmdd') || '_' ||'$INSTANCE_NAME' || '_' || to_char(min(snap_id)) || '_' ||
to_char(max(snap_id)) ||'.html' file_name
from dba_hist_snapshot t
where t.end_interval_time between trunc(sysdate) + $1 / 24 and
trunc(sysdate) + ($2 + 1) / 24;
exit;
EOF`
echo " instance_name $INSTANCE_NAME"
echo " FILE_NAME $FILE_NAME"
sqlplus "$3" << EOF
column dbid new_value dbid;
select dbid from v\$database;
column instance_number new_value instance_number;
select instance_number instance_number from v\$instance;
column max_id new_value end_snap;
column min_id new_value begin_snap;
select to_char(max(snap_id)) max_id,
to_char(min(snap_id)) min_id
from dba_hist_snapshot t
where t.end_interval_time between trunc(sysdate) + $1 / 24 and
trunc(sysdate) + ($2 + 1) / 24;
set echo off;
set veri off;
set feedback off;
set termout on;
set heading off;
set linesize 1500;
set trimspool on;
spool $FILE_NAME;
select output from table(dbms_workload_repository.AWR_REPORT_HTML(&dbid, &instance_number,&begin_snap, &end_snap,0 ));
spool off;
EOF
echo "Report file name is : "$FILE_NAME
echo "AWR report of $INSTANCE_NAME " | mutt -s "[info]AWR report of $INSTANCE_NAME ${TODAY}" -a "$FILE_NAME" eymitwu@hotmail.com
傳送的郵件和主題不要忘記修改,run.sh我們在下面進行介紹
4 使用方法
可以看到呼叫awrrpt指令碼需要傳三個引數,分別為開始時間,結束時間,連線資料庫的使用者名稱密碼還有tns,下面Run.sh配置了兩個資料9點至11點的AWR報告,資料庫只需要修改run.sh就可以了
[oracle@svr7-71 awrrpt]$ more run.sh
./awrrpt.sh 9 11 test1/test1@ora71
./awrrpt.sh 9 11 test1/test1@ora72
最後別忘記把要生成資料庫的tnsname配置到tnsnames.ora中,最後把run.sh配置到crontab中
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/21605631/viewspace-730827/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【AWR】Oracle批量生成awr報告指令碼Oracle指令碼
- awr報告每天自動生成指令碼指令碼
- Oracle生成awr報告操作步驟Oracle
- ORACLE AWR效能報告和ASH效能報告的解讀Oracle
- Win10系統如何阻止自動傳送錯誤報告Win10
- 【python3.x】傳送自動化測試報告郵件Python測試報告
- Oracle 12.2 physical standby備庫收集AWR報告Oracle
- 【效能調優】Oracle AWR報告指標全解析Oracle指標
- Oracle 11.2.0.4 awr過期快照無法自動清理Oracle
- Springboot 自動傳送郵件Spring Boot
- Python新型冠狀病毒疫情資料自動爬取+統計+傳送報告+資料螢幕(三)傳送篇Python
- Gitlab整合Sonarqube自動檢測程式碼併傳送報告給提交者Gitlab
- Unittest單元測試框架——BeautifulReport測試報告和Yagmail自動傳送郵件框架測試報告AI
- ORACLE AWROracle
- win10 關閉自動傳送錯誤報告方法 windows10錯誤報告怎麼關閉Win10Windows
- AWR報告基礎操作
- 【python介面自動化】- 使用requests庫傳送http請求PythonHTTP
- oracle rac 單個例項不能生成awr報告的問題Oracle
- gnome-shell 使用 notify-send 傳送桌面訊息
- 使用oracle job定時傳送email郵件OracleAI
- 讓 Emacs shell 命令傳送桌面通知Mac
- 如何在shell指令碼里使用sftp批次傳送檔案指令碼FTP
- Python3實現自動傳送MySql查詢併傳送郵件PythonMySql
- Oracle 11.2.0.3.0中執行awrrpt.sql生成awr報告報ora-06502錯誤OracleSQL
- shell指令碼:批次傳送curl請求指令碼
- 傳送kafka訊息的shell指令碼Kafka指令碼
- oracle工具 awr formatOracleORM
- 【AWR】Oracle資料庫建立awr基線Oracle資料庫
- 【玩具】使用Python自動化傳送微信訊息進行訂水Python
- awr-----一份經典的負載很高的awr報告負載
- 12.2 如何單為PDB建立AWR報告
- nodejs什麼值得買自動簽到自動評論郵件傳送NodeJS
- 介面自動化使用requests生成測試報告測試報告
- 用oracle傳送電子郵件Oracle
- oracle 傳送郵件 實現方法Oracle
- e語言自動傳送訊息【win11】
- python+pytest介面自動化傳送post請求Python
- Gitlab伺服器郵箱配置,實現自動為使用者傳送郵件(註冊傳送驗證連結)Gitlab伺服器
- GUI圖形化自動化框架研發V4.0(傳送缺陷報告至開發人員郵箱)GUI框架