怎么获取AWR的脚本
发表于:2025-02-06 作者:千家信息网编辑
千家信息网最后更新 2025年02月06日,本篇内容介绍了"怎么获取AWR的脚本"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!#!/bin/ba
千家信息网最后更新 2025年02月06日怎么获取AWR的脚本
本篇内容介绍了"怎么获取AWR的脚本"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
#!/bin/bash#by raysuen#v02. ~/.bash_profileAWR_FORMAT=htmlNUM_DAYS=2#############################################获取指定时间的snapid的函数############################################getsnapID(){ BEGIN_SNAP_ID=`sqlplus -S / as sysdba <<-RAY set heading off trimspool on feedback off SELECT trim(SNAP_ID) FROM DBA_HIST_SNAPSHOT a,v\\$instance b where to_char(END_INTERVAL_TIME,'yyyymmddhh34')='$1' and a.instance_number=b.instance_number; RAY` END_SNAP_ID=`sqlplus -S / as sysdba <<-RAY set heading off trimspool on feedback off SELECT trim(SNAP_ID) FROM DBA_HIST_SNAPSHOT a,v\\$instance b where to_char(END_INTERVAL_TIME,'yyyymmddhh34')='$2' and a.instance_number=b.instance_number; RAY` #判断获取的snapid是否为空 if [ -z ${BEGIN_SNAP_ID} ];then echo "The script can not get a valid snap id,please enter a right time for -b." exit 96 fi if [ -z ${BEGIN_SNAP_ID} ];then echo "The script can not get a valid snap id,please enter a right time for -e." exit 96 fi BEGIN_SNAP_ID=`echo ${BEGIN_SNAP_ID} | sed 's/ //g'` END_SNAP_ID=`echo ${END_SNAP_ID} | sed 's/ //g'`}#############################################获取帮助的函数############################################my_fun(){ echo "SYNOPSIS:" echo " ./GET_AWR.sh -b begin_time -e end_time -n awr_name" echo "OPTIONS:" echo " -b specify a time for begin time of awr,format yyyymmddhh34" echo " -e specify a time for begin time of awr,format yyyymmddhh34" echo " -n specify a name for name of awr" echo "EXAMPLE:" echo " ./GET_AWR.SH -b 2019051708 -e 2019051709 -n test" echo " ./GET_AWR.sh -b \`date +'%Y%m%d18' -d '+1 day ago'\` -e \`date +'%Y%m%d19' -d '+1 day ago'\` -n test"}#############################################脚本入口,获取参数############################################if [ $# -lt 1 ];then echo "You must specify parameters:" echo " -b begin time of awr" echo " -e end time of awr" exit 99fiwhile (($#>=1))do if [ "$1" == "-b" ];then shift awrbegintime=$1 shift continue fi if [ "$1" == "-e" ];then shift awrendtime=$1 shift continue fi if [ "$1" == "-n" ];then shift awrname=$1 shift continue fi if [ "$1" == "-h" ];then my_fun exit 0 fi shiftdone#############################################健壮性检查#############################################参数不可以为空if [ -z ${awrbegintime} ];then echo "You must specify parameters:-b for begin time of awr" exit 98fiif [ -z ${awrendtime} ];then echo "You must specify parameters:-e for end time of awr" exit 98fiif [ -z ${awrname} ];then echo "You must specify parameters:-n for report name of awr" exit 98fi#判断参数为时间date -d "${awrbegintime:0:8} ${awrbegintime:8:2}" > /dev/null 2>&1if [ $? -ne 0 ];then echo "The valus of -b is invalid date." exit 97fidate -d "${awrendtime:0:8} ${awrendtime:8:2}" > /dev/null 2>&1if [ $? -ne 0 ];then echo "The valus of -e is invalid date." exit 97fi#############################################执行函数,获取snap id############################################getsnapID ${awrbegintime} ${awrendtime}#############################################定义awr报告的路径############################################AWR_LOG=/u02/logout/awr/AWR_${awrname}_${awrbegintime}_${awrendtime}.html#############################################获取awr报告############################################echo -e "$AWR_FORMAT\n$NUM_DAYS\n$BEGIN_SNAP_ID\n$END_SNAP_ID\n$AWR_LOG\n"|(sqlplus -S / as sysdba @?/rdbms/admin/awrrpt.sql) > /dev/null#############################################帮助:# 参数区分大小写# -b awr的开始时间,格式:yyyymmddhh34# -e awr的结束时间,格式:yyyymmddhh34# -n awr报告中的名字#例子:# ./GET_AWR.SH -b "2019051708" -e "2019051709" -n test# ./GET_AWR.sh -b `date +'%Y%m%d18' -d '+1 day ago'` -e `date +'%Y%m%d19' -d '+1 day ago'` -n test############################################
"怎么获取AWR的脚本"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
参数
报告
时间
脚本
内容
函数
更多
格式
知识
健壮
实用
学有所成
接下来
例子
名字
困境
大小
实际
情况
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
北京软件开发系统
高新科技互联网企业
实时数据库的英文
大专计算机网络技术工程师
新时代网络安全的思考3000字
网络安全与执法类 视力
软件开发一定要设计文档吗
网络安全法和网络安全教育
北京软件开发者攻略
mc服务器推荐战争服无主城
cnk期刊论文数据库
智慧工地软件开发方案
电脑管理服务器
星际战甲信条服务器哪个好
软件开发需要用到哪些算法
开启网络技术的好处
安阳app软件开发
网络安全法受到刑事几年内
服务器远程不能修改文件
口袋西游怎么选择服务器区域
工业网络安全手册
数据库查询操作实验报告总结
计算机服务器的英文缩写为cnn
网络安全课题调研开题报告
计算机网络技术女生多
e5服务器cpu是几核
惠普c7000服务器风扇调速
neo4j是什么类型数据库
switch总是服务器运行错误
数据库运维工程师面试题