自動監控Oracle 表空間資訊併傳送郵件指令碼
伺服器越來越多了,日常管理起來也越來越麻煩,也沒找到特別稱心如意的工具,如何自動的監控Oracle 告警日誌和表空間資訊呢?加入一臺伺服器有多個例項又如何監控呢?自己動手寫了一個小shell,貼出來以備後續更新!若有更好的可以不防共享出來哈
#!/bin/ksh
# script name is check_tablespace.sh
# created date: 2015-01-05
# guijian
################################### check information about oracle tablespace ####################################
if [ -d "$HOME/.check_tbs" ];then
echo "dir:$HOME/.check_tbs exists"
else
mkdir $HOME/.check_tbs
echo "dir:$HOME/.check_tbs created!"
fi
host_name=`hostname`
host_ip=`grep Crsz6scsdb02 /etc/hosts | grep -v '127.0.1.1' | grep -v localhost`
mail_list="guijian5@crc.com.hk"
oper_version=`uname -a | awk '{print $1}'`
if [ $oper_version = "Linux" ];then
ora_sid=`ps -ef | grep ora_pmon | grep -v grep |awk '{print $8}'|cut -d '_' -f3 | xargs`
sh $HOME/.bash_profile
else
ora_sid=`ps -ef | grep ora_pmon | grep -v grep |awk '{print $9}'|cut -d '_' -f3 | xargs`
sh $HOME/.profile
fi
echo "ora_sid:$ora_sid"
cat "######################### check information about oracle tablespace ##########################" > $HOME/.check_tbs/tbs.log
for i in $ora_sid
do
export ORACLE_SID=$i
echo $ORACLE_SID
alert_logfile=`find $ORACLE_BASE/ -name alert_$ORACLE_SID.log`
cd $logdir
number1=`cat $HOME/.check_tbs/tmp_alert_number`
sed -n "$number1,\$p" $alert_logfile > $HOME/.check_tbs/tmp_alert.log
wc -l $alert_logfile | awk '{print $1}' > $HOME/.check_tbs/tmp_alert_number
cat $HOME/.check_tbs/tmp_alert.log | grep -E 'ORA-|RMAN-' > $HOME/.check_tbs/alertlog_check.log
sqlplus -S /nolog<>$HOME/.check_tbs/tbs.log
conn / as sysdba
set line 140 pagesize 9999
col tablespace_name for a30
select instance_name,status from gv\$instance;
select T.tablespace_name,T.TOTAL_SPACE_MB,(T.TOTAL_SPACE_MB-F.FREE_SPACE_MB) "USED_SPACE_MB",F.FREE_SPACE_MB,(100-ROUND((T.TOTAL_SPACE_MB-F.FREE_SPACE_MB)/T.TOTAL_SPACE_MB*100,2)) "FREE_RATE %",ROUND((T.TOTAL_SPACE_MB-F.FREE_SPACE_MB)/T.TOTAL_SPACE_MB*100,2) "USED_RATE %" FROM (SELECT TABLESPACE_NAME,SUM(BYTES/1024/1024) "TOTAL_SPACE_MB" FROM DBA_DATA_FILES GROUP BY TABLESPACE_NAME) T,(SELECT TABLESPACE_NAME,ROUND(SUM(BYTES/1024/1024),2) "FREE_SPACE_MB" FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME) F WHERE T.TABLESPACE_NAME = F.TABLESPACE_NAME ORDER BY 6;
EOF
done
sed '/^$/d' $HOME/.check_tbs/tbs.log > $HOME/.check_tbs/tablespace.log
echo "#################################### alert log check #########################################" >> $HOME/.check_tbs/tablespace.log
cat $HOME/.check_tbs/alertlog_check.log >> $HOME/.check_tbs/tablespace.log
cat $HOME/.check_tbs/tablespace.log |mail -s "INSTANCE_NAME : $ora_sid HOST NAME AND IP ADDRESS : $host_ip" $mail_list
轉載請註明出處
#!/bin/ksh
# script name is check_tablespace.sh
# created date: 2015-01-05
# guijian
################################### check information about oracle tablespace ####################################
if [ -d "$HOME/.check_tbs" ];then
echo "dir:$HOME/.check_tbs exists"
else
mkdir $HOME/.check_tbs
echo "dir:$HOME/.check_tbs created!"
fi
host_name=`hostname`
host_ip=`grep Crsz6scsdb02 /etc/hosts | grep -v '127.0.1.1' | grep -v localhost`
mail_list="guijian5@crc.com.hk"
oper_version=`uname -a | awk '{print $1}'`
if [ $oper_version = "Linux" ];then
ora_sid=`ps -ef | grep ora_pmon | grep -v grep |awk '{print $8}'|cut -d '_' -f3 | xargs`
sh $HOME/.bash_profile
else
ora_sid=`ps -ef | grep ora_pmon | grep -v grep |awk '{print $9}'|cut -d '_' -f3 | xargs`
sh $HOME/.profile
fi
echo "ora_sid:$ora_sid"
cat "######################### check information about oracle tablespace ##########################" > $HOME/.check_tbs/tbs.log
for i in $ora_sid
do
export ORACLE_SID=$i
echo $ORACLE_SID
alert_logfile=`find $ORACLE_BASE/ -name alert_$ORACLE_SID.log`
cd $logdir
number1=`cat $HOME/.check_tbs/tmp_alert_number`
sed -n "$number1,\$p" $alert_logfile > $HOME/.check_tbs/tmp_alert.log
wc -l $alert_logfile | awk '{print $1}' > $HOME/.check_tbs/tmp_alert_number
cat $HOME/.check_tbs/tmp_alert.log | grep -E 'ORA-|RMAN-' > $HOME/.check_tbs/alertlog_check.log
sqlplus -S /nolog<
conn / as sysdba
set line 140 pagesize 9999
col tablespace_name for a30
select instance_name,status from gv\$instance;
select T.tablespace_name,T.TOTAL_SPACE_MB,(T.TOTAL_SPACE_MB-F.FREE_SPACE_MB) "USED_SPACE_MB",F.FREE_SPACE_MB,(100-ROUND((T.TOTAL_SPACE_MB-F.FREE_SPACE_MB)/T.TOTAL_SPACE_MB*100,2)) "FREE_RATE %",ROUND((T.TOTAL_SPACE_MB-F.FREE_SPACE_MB)/T.TOTAL_SPACE_MB*100,2) "USED_RATE %" FROM (SELECT TABLESPACE_NAME,SUM(BYTES/1024/1024) "TOTAL_SPACE_MB" FROM DBA_DATA_FILES GROUP BY TABLESPACE_NAME) T,(SELECT TABLESPACE_NAME,ROUND(SUM(BYTES/1024/1024),2) "FREE_SPACE_MB" FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME) F WHERE T.TABLESPACE_NAME = F.TABLESPACE_NAME ORDER BY 6;
EOF
done
sed '/^$/d' $HOME/.check_tbs/tbs.log > $HOME/.check_tbs/tablespace.log
echo "#################################### alert log check #########################################" >> $HOME/.check_tbs/tablespace.log
cat $HOME/.check_tbs/alertlog_check.log >> $HOME/.check_tbs/tablespace.log
cat $HOME/.check_tbs/tablespace.log |mail -s "INSTANCE_NAME : $ora_sid HOST NAME AND IP ADDRESS : $host_ip" $mail_list
轉載請註明出處
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28612416/viewspace-1392423/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 用 Linux Shell 指令碼來監控磁碟使用情況併傳送郵件Linux指令碼
- Python監控程序資源佔用併傳送郵件Python
- Oracle 自動化運維-Python表空間郵件預警Oracle運維Python
- Springboot 自動傳送郵件Spring Boot
- Python3實現自動傳送MySql查詢併傳送郵件PythonMySql
- 利用Oracle資料庫傳送郵件Oracle資料庫
- 【Grafana】告警配置併傳送郵件Grafana
- 用oracle傳送電子郵件Oracle
- oracle 傳送郵件 實現方法Oracle
- JAVA 資料寫入excel併傳送郵件JavaExcel
- 郵件和簡訊傳送
- SpringBoot整合Mail傳送郵件&傳送模板郵件Spring BootAI
- 案例二十每分鐘監控錯誤日誌併傳送郵件給相關人員
- Python 壓縮資料夾併傳送郵件功能Python
- 郵件傳送
- 傳送郵件
- 谷歌郵箱,配置傳送郵件密碼谷歌密碼
- 使用oracle job定時傳送email郵件OracleAI
- laravel 傳送郵件修改密碼Laravel密碼
- java郵件傳送Java
- python傳送郵件Python
- Django——郵件傳送Django
- gmail傳送郵件AI
- phpcms傳送郵件PHP
- 郵件的傳送
- Laravel 傳送郵件Laravel
- thinkjs 傳送郵件JS
- SpringBoot傳送郵件Spring Boot
- SpringBoot郵件傳送Spring Boot
- Laravel傳送郵件Laravel
- PHP傳送郵件PHP
- nodejs 傳送郵件NodeJS
- Oracle 建立表空間和使用者指令碼Oracle指令碼
- 郵件營銷自動化:批次郵箱API傳送技巧與策略API
- 功能較全的oracle傳送郵件過程Oracle
- Laravel 重置密碼傳送郵件分析Laravel密碼
- nodejs什麼值得買自動簽到自動評論郵件傳送NodeJS
- sqlserver監控指令碼_發現某個等待就發出郵件SQLServer指令碼
- Java Mail 郵件傳送(二):簡單封裝的郵件傳送JavaAI封裝