AWR报告自动采集脚本

脚本文件放在D:\OScheck目录下,截图如下:


CRT是SecureCRT软件,LOGS存放生成的日志文件,ServerList是服务器列表


DAILYCheck.bat文件内容:

REM DAILYCheck.bat
@echo off
Setlocal ENABLEDELAYEDEXPANSION
Set strDate=%date:~0,4%%date:~5,2%%date:~8,2%
REM=================================================================================
cls
color 0a
title  巡检工具
:begin
cls
echo.
%~d0
cd %~dp0
set TempDir=d:\AWR_oracle\temp
if not exist  %TempDir% mkdir %TempDir%
echo.
echo             ﹎.巡检工具——数据库巡检.﹎    
echo.
echo            ╔═════════════╗
echo            ║  1、数据库AWR(Linux)   ║
echo            ║  2、数据库AWR(Unix)    ║
echo            ╚═════════════╝
echo                0、退出程序!
echo.
set num=99
set /p num=" 请输入选择数字,然后按回车:"
if %num%==1 goto Linux_begin
if %num%==2 goto Unix_begin
if %num%==0 exit
echo.
goto begin

:Linux_begin
echo.
echo     时间格式(YYYYMMDDHH),如:2015041400
echo.
set time_from=0
set time_to=0
set /p time_from=" 请输入开始时间,然后按回车:"
set /p time_to=" 请输入结束时间,然后按回车:"
echo.
echo     开始时间: %time_from%
echo     结束时间: %time_to%
if %time_from%==0 goto Linux_begin
if %time_to%==0 goto Linux_begin
echo     直接回车确认输入时间(输入0退出程序,输入1修改时间,输入2回到主界面)
echo.
set Linux_num=99
set /p Linux_num=" 回车确认输入时间:"
if %Linux_num%==99 goto Linux_end
if %Linux_num%==1 goto Linux_begin
if %Linux_num%==2 goto begin
if %Linux_num%==0 exit
:Linux_end
set SvrList=d:\AWR_oracle\ServerList\svrLinux.list
set Checklog=%TempDir%\oracle_AWR_%strDate%_Linux.log
set CheckDir=d:\AWR_oracle\AWR_%strDate%\Linux
echo.
echo  :::Start Oracle AutoAWRRPT on %date%
echo  :::Start Oracle AutoAWRRPT on %date% > %checklog%
echo.
echo  ===================================================================
echo.
For /F "tokens=1,2,3,4,5 delims=," %%i in (%SvrList%) do (
echo %date%:: %%k :: %%i :: %%j >> %checklog%
echo  ==================主机: %%k ,开始检测,请稍等==================
"d:\AWR_oracle\CRT\SecureCRT.exe" /TITLEBAR "OSCheck:%%k:%%i:%%j"/NOMENU /NOTOOLBAR /SCRIPT d:\AWR_oracle\Dailycheck.vbs /ARG %%l /ARG %%m /ARG %%i /ARG %%j /ARG %time_from% /ARG %time_to% >> %checklog%
echo  ==================主机: %%k ,完成检测,请核查==================
echo.
)
goto end

:Unix_begin
echo.
echo     时间格式(YYYYMMDDHH),如: 2015041400
echo.
set time_from=0
set time_to=0
set /p time_from=" 请输入开始时间,然后按回车:"
set /p time_to=" 请输入结束时间,然后按回车:"
echo.
echo     开始时间: %time_from%
echo     结束时间: %time_to%
if %time_from%==0 goto Unix_begin
if %time_to%==0 goto Unix_begin
echo     直接回车确认输入时间 (输入0退出程序,输入1修改时间,输入2回到主界面)
echo.
set Unix_num=99
set /p Unix_num=" 回车确认输入时间:"
if %Unix_num%==99 goto Unix_end
if %Unix_num%==1 goto Unix_begin
if %Unix_num%==2 goto begin
if %Unix_num%==0 exit
:Unix_end
set SvrList=d:\AWR_oracle\ServerList\svrUnix.list
set Checklog=%TempDir%\oracle_AWR_%strDate%_Unix.log
set CheckDir=d:\AWR_oracle\AWR_%strDate%\Unix
echo.
echo  :::Start Oracle AutoAWRRPT on %date%
echo  :::Start Oracle AutoAWRRPT on %date% >> %checklog%
echo.
echo  ===================================================================
echo.
For /F "tokens=1,2,3,4,5 delims=," %%i in (%SvrList%) do (
echo %date%:: %%k :: %%i :: %%j >> %checklog%
echo  ==================主机: %%k ,开始检测,请稍等==================
"d:\AWR_oracle\CRT\SecureCRT.exe" /TITLEBAR "OSCheck:%%k:%%i:%%j"/NOMENU /NOTOOLBAR /SCRIPT d:\AWR_oracle\Dailycheck_UNIX.vbs /ARG %%l /ARG %%m /ARG %%i /ARG %%j /ARG %time_from% /ARG %time_to% >> %checklog%
echo  ==================主机: %%k ,完成检测,请核查==================
echo.
)
goto end
:end
REM - 检查完毕后将下载到本地的检查日志移到一个目录中。
if not exist  %CheckDir% mkdir %CheckDir%
Move /Y %TempDir%\*.log %checkDir%
Move /Y %TempDir%\*.html %checkDir%
goto begin

Dailycheck.vbs文件内容:

# $language = "VBScript"
# $interface = "1.0"

Sub Main
   dim objTab, objSFTPTab
   dim strHost, strUserid, strUserPwd, strPort, strFrom, strTo
   dim strConnect
   IF crt.arguments.count <> 6 then
       crt.Daiglog.MessageBox("No Enough Paratmeters!")
       crt.quit
       exit sub
   ELSE
   strUserid = crt.arguments(0)
   strUserPwd = crt.arguments(1)
   strHost = crt.arguments(2)
   strPort = crt.arguments(3)
   strFrom = crt.arguments(4)
   strTo = crt.arguments(5)
   END IF
  
'======================================================================================================
   'Connect to a host and start OS check daily 
   strConnect="/SSH2 /P " & strPort & " /L " & strUserId & " /PASSWORD " & strUserPwd & " " & strHost 
  set objTab=crt.session.connectInTab(strConnect)
  objTab.screen.synchronous = True

  'Create an SFTP tab associated with the existing tab
   set objSFTPTab=objTab.connectSFTP
  'Wait for the SFTP tab to be ready for input
  objSFTPTab.screen.synchronous = True
  crt.Sleep 300
  objSFTPTab.screen.Send vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "lcd d:\AWR_oracle\"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "cd /home/oracle/gyl/AWR/"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "put -a autoawrrpt.sh"  & vbcr
  objSFTPTab.screen.WaitForString "Uploading"
  objSFTPTab.screen.WaitForString "sftp>"

  objTab.activate()
   crt.sleep 10
   objTab.screen.waitforstring("#")
   objTab.screen.send("chmod +x /home/oracle/gyl/AWR/autoawrrpt.sh") & chr(13)
   objTab.screen.waitforstring("autoawrrpt.sh") 
   objTab.screen.send("su - oracle") & chr(13)
   objTab.screen.waitforstring("$") 
   objTab.screen.send("sh /home/oracle/gyl/AWR/autoawrrpt.sh -s orcl -f " & strFrom & " -t " & strTo & " -p html ") & chr(13)
   objTab.screen.waitforstring("successfully")

   objSFTPTab.activate()
   ' download the check log to d:\AWR_oracle\temp from remote working Directory /home/oracle/gyl/AWR/
  objSFTPTab.Screen.Send "lcd d:\AWR_oracle\temp\"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
   objSFTPTab.Screen.Send ("get -a /home/oracle/gyl/AWR/awrrpt_orcl*.html" ) & vbcr
   objSFTPTab.screen.WaitForString "Downloading"
    objSFTPTab.screen.WaitForString "sftp>"
   'Close the SFTPTab
   objSFTPTab.screen.send ("exit") & vbcr
   
   objTab.activate()
   objTab.Screen.send("echo r001") & chr(13)
   objTab.Screen.WaitForString("r001") 
   objTab.Session.Disconnect
   'objTab.close
 
   'Done, quit SecureCRT
    crt.quit
End Sub

Dailycheck_UNIX.vbs文件内容:

# $language = "VBScript"
# $interface = "1.0"

Sub Main
   dim objTab, objSFTPTab
   dim strHost, strUserid, strUserPwd, strPort, strFrom, strTo
   dim strConnect
   IF crt.arguments.count <> 6 then
       crt.Daiglog.MessageBox("No Enough Paratmeters!")
       crt.quit
       exit sub
   ELSE
   strUserid = crt.arguments(0)
   strUserPwd = crt.arguments(1)
   strHost = crt.arguments(2)
   strPort = crt.arguments(3)
   strFrom = crt.arguments(4)
   strTo = crt.arguments(5)
   END IF
  
'======================================================================================================
   'Connect to a host and start OS check daily 
   strConnect="/SSH2 /P " & strPort & " /L " & strUserId & " /PASSWORD " & strUserPwd & " " & strHost 
  set objTab=crt.session.connectInTab(strConnect)
  objTab.screen.synchronous = True

  'Create an SFTP tab associated with the existing tab
   set objSFTPTab=objTab.connectSFTP
  'Wait for the SFTP tab to be ready for input
  objSFTPTab.screen.synchronous = True
  crt.Sleep 300
  objSFTPTab.screen.Send vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "lcd d:\AWR_oracle\"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "cd /home/oracle/gyl/AWR/"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
  objSFTPTab.Screen.Send "put -a autoawrrpt_UNIX.sh"  & vbcr
  objSFTPTab.screen.WaitForString "Uploading"
  objSFTPTab.screen.WaitForString "sftp>"

  objTab.activate()
   crt.sleep 10
   objTab.screen.waitforstring("#")
   objTab.screen.send("chmod +x /home/oracle/gyl/AWR/autoawrrpt_UNIX.sh ; echo r000") & chr(13)
   objTab.screen.waitforstring("r000") 
   objTab.screen.send("su - oracle") & chr(13)
   objTab.screen.waitforstring("$") 
   objTab.screen.send("sh /home/oracle/gyl/AWR/autoawrrpt_UNIX.sh -s orcl -f " & strFrom & " -t " & strTo & " -p html ") & chr(13)
   objTab.screen.waitforstring("successfully")

   objSFTPTab.activate()
   ' download the check log to d:\AWR_oracle\temp from remote working Directory /home/oracle/gyl/AWR/
  objSFTPTab.Screen.Send "lcd d:\AWR_oracle\temp\"  & vbcr
  objSFTPTab.Screen.WaitForString "sftp>"
   objSFTPTab.Screen.Send ("get -a /home/oracle/gyl/AWR/awrrpt_orcl*.html" ) & vbcr
   objSFTPTab.screen.WaitForString "Downloading"
    objSFTPTab.screen.WaitForString "sftp>"
   'Close the SFTPTab
   objSFTPTab.screen.send ("exit") & vbcr
   
   objTab.activate()
   objTab.Screen.send("echo r001") & chr(13)
   objTab.Screen.WaitForString("r001") 
   objTab.Session.Disconnect
   'objTab.close
 
   'Done, quit SecureCRT
    crt.quit
End Sub

autoawrrpt.sh文件内容:

#!/bin/bash
# ********************************
# * autoawrrpt.sh
# ********************************
# ./autoawrrpt.sh -s orcl -f 2015110900 -t 2015111000 -p html -h ${ORACLE_HOME}
# Usage: autoawrrpt.sh -s [instance_name]
#          -f [from time]
#          -t [to time]
#          -p [report type, html or text]
#          -h [oracle home]
#          -n [tns admin]
#
#         time format: 'yyyymmddhh24'.
#         E.g 2015030417 means 05pm, Mar 04, 2015
#
#
# **********************
# get parameters
# **********************
oracle_home=${ORACLE_HOME}
  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
}
# *******************************
# read interchange ID & passwd
# *******************************
#read_act()
#{
#echo "interchange ID: "
#read user
#echo "password: "
#stty -echo
#read pswd
#stty echo
#}
# *******************************
# get begin and end snapshot ID
# *******************************
define_dur()
{
begin_id=`$sqlplus -s /nolog<<EOF
  conn /as sysdba
  set pages 0
  set head off
  set feed off
  select max(SNAP_ID) from DBA_HIST_SNAPSHOT where BEGIN_INTERVAL_TIME<=to_date($from,'yyyymmddhh24');
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<<EOF
  conn /as sysdba
  set pages 0
  set head off
  set feed off
  select min(SNAP_ID) from DBA_HIST_SNAPSHOT where END_INTERVAL_TIME>=to_date($to,'yyyymmddhh24');
  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
  IPAddress=`/sbin/ifconfig|grep 'inet addr:'|head -1|awk '{print $2}'|sed 's/addr://g'`;
  if [ $type = "text" ]
  then
    report_name="awrrpt_${instance}_${begin_id}_${end_id}_${from}_${to}_${IPAddress}.txt"
  else
    report_name="awrrpt_${instance}_${begin_id}_${end_id}_${from}_${to}_${IPAddress}.html"
  fi
  echo $report_name
$sqlplus -s "/as sysdba">/dev/null<<EOF
      set term off
      define report_type=$type
      define num_days=9
      define begin_snap=${begin_id}
      define end_snap=${end_id}
      define report_name=${report_name}
      @${oracle_home}/rdbms/admin/awrrpt.sql
      exit;
EOF
}
# *******************************
# main routing
# *******************************
#read_act
cd /home/oracle/gyl/AWR/
rm -rf /home/oracle/gyl/AWR/awrrpt_orcl*.html
define_dur
generate_awr
echo successfully

autoawrrpt_UNIX.sh文件内容:

#!/bin/bash
# ********************************
# * autoawrrpt.sh
# ********************************
# ./autoawrrpt.sh -s orcl -f 2015110900 -t 2015111000 -p html -h ${ORACLE_HOME}
# Usage: autoawrrpt.sh -s [instance_name]
#          -f [from time]
#          -t [to time]
#          -p [report type, html or text]
#          -h [oracle home]
#          -n [tns admin]
#
#         time format: 'yyyymmddhh24'.
#         E.g 2015030417 means 05pm, Mar 04, 2015
#
#
# **********************
# get parameters
# **********************
oracle_home=${ORACLE_HOME}
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
# ********************
trim()
{
#local result
result=`echo $1|sed 's/^ *//g' | sed 's/ *$//g'`
echo $result
}
# *******************************
# read interchange ID & passwd
# *******************************
#read_act()
#{
#echo "interchange ID: "
#read user
#echo "password: "
#stty -echo
#read pswd
#stty echo
#}
# *******************************
# get begin and end snapshot ID
# *******************************
define_dur()
{
begin_id=`$sqlplus -s /nolog<<EOF
conn /as sysdba
set pages 0
set head off
set feed off
select max(SNAP_ID) from DBA_HIST_SNAPSHOT where BEGIN_INTERVAL_TIME<=to_date($from,'yyyymmddhh24');
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<<EOF
conn /as sysdba
set pages 0
set head off
set feed off
select min(SNAP_ID) from DBA_HIST_SNAPSHOT where END_INTERVAL_TIME>=to_date($to,'yyyymmddhh24');
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 [ ! -f "$awrsql" ]
then
echo "awrrpt.sql does not exist, exiting..."
exit 20
fi
IPAddress=`ifconfig lan900 | grep 'inet' | awk '{print $2}'`;
if [ $type = "text" ]
then
report_name="awrrpt_${instance}_${begin_id}_${end_id}_${from}_${to}_${IPAddress}.txt"
else
report_name="awrrpt_${instance}_${begin_id}_${end_id}_${from}_${to}_${IPAddress}.html"
fi
echo $report_name
$sqlplus -s "/as sysdba">/dev/null<<EOF
set term off
define report_type=$type
define num_days=9
define begin_snap=${begin_id}
define end_snap=${end_id}
define report_name=${report_name}
@${oracle_home}/rdbms/admin/awrrpt.sql
exit;
EOF
}
# *******************************
# main routing
# *******************************
#read_act
cd /home/oracle/gyl/AWR/
rm -rf /home/oracle/gyl/AWR/awrrpt_orcl*.html
define_dur
generate_awr
echo successfully

D:\AWR_oracle\ServerList目录下是服务器列表,可分为Linux和Unix



服务器列表文件格式(ip,端口,主机名,用户名,密码)如下:



双击执行DAILYCheck.bat文件,需要输入AWR报告采集的时间段,界面如下:


猜你喜欢

转载自blog.csdn.net/guoyanliang1985/article/details/80906587