SHELL版的自动批量生成AWR报告的脚本

本文介绍了一个使用Shell脚本批量生成Oracle AWR报告的方法。脚本通过接收参数实例名、开始时间、结束时间和报告类型,利用SQL*Plus连接数据库获取快照ID并生成HTML或TEXT类型的AWR报告。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上文里面的功能,对比着用shell来实现,比较好玩

 

用法:

bash ./dba_oracle_awr.sh -s ORCL -f 20110312070000 -t 20110312090000 -p TEXT -h /usr/local/oracle/10.2.0-64

 

脚本:

#!/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 20110304170000 means 05:00:00pm, Mar 04, 2011
#
#

# **********************
# 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
}

# *******************************
# 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 $user/$pswd@$instance
  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<<EOF
  conn $user/$pswd@$instance
  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 $user/$pswd@$instance>/dev/null<<EOF
      set term off
      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

为了实现文件夹内容的自动对比和本更新,你可以使用CheckDiff和AutoRemove这两个Python脚本。CheckDiff.py 脚本可以用来检测文件夹之间的差异,而AutoRemove.py 脚本则用于根据差异记录来执行删除操作。下面将提供一个基础的操作步骤来帮助你完成文件对比与更新的自动化过程。 参考资源链接:[Python实现批量文件对比与更新的自动化工具](https://wenku.youkuaiyun.com/doc/36awr2qdg2?spm=1055.2569.3001.10343) 首先,确保你已经安装了Python环境,并且熟悉Python的基本语法和文件操作。接下来,你需要获取这两个脚本的源码。你可以通过查看资源《Python实现批量文件对比与更新的自动化工具》来获取CheckDiff.py和AutoRemove.py的具体实现。 具体操作步骤如下: 1. 打开CheckDiff.py脚本,配置源文件夹和目标文件夹的路径,然后运行该脚本脚本自动对比两个文件夹的内容,并生成差异报告。 2. 检查差异报告,确认新增和修改的文件是否符合预期。然后,将这些文件复制到目标文件夹中,更新文件内容。 3. 根据差异报告中的删除记录,运行AutoRemove.py脚本。该脚本会根据记录删除那些在源文件夹中已经被删除的文件。 在这个过程中,你可能会需要了解如何使用Python标准库中的文件操作相关的模块,例如os和shutil,这些模块可以帮助你轻松地完成文件的复制、移动和删除等操作。如果你希望进一步提高脚本的效率和功能,可以考虑引入Python的第三方库,例如difflib和pathlib,这些库提供了更多的工具和方法来进行文件比较和路径操作。 通过实践上述步骤,你将能够实现一个高效的文件管理自动化工具,从而在项目文件本更新时节省大量的时间和精力。为了更深入地理解和掌握这些技术,建议详细阅读资源《Python实现批量文件对比与更新的自动化工具》,这将帮助你了解脚本的内部机制,以及如何进一步优化和扩展这些工具的功能。 参考资源链接:[Python实现批量文件对比与更新的自动化工具](https://wenku.youkuaiyun.com/doc/36awr2qdg2?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值