返回顶部
首页 > 资讯 > 数据库 >怎么获取AWR的脚本
  • 315
分享到

怎么获取AWR的脚本

2024-04-02 19:04:59 315人浏览 八月长安
摘要

本篇内容介绍了“怎么获取AWR的脚本”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!#!/bin/bash

本篇内容介绍了“怎么获取AWR的脚本”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

#!/bin/bash
#by raysuen
#v02
. ~/.bash_profile
AWR_FORMAT=html
NUM_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 99
fi
while (($#>=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
	shift
done
############################################
#健壮性检查
############################################
#参数不可以为空
if [ -z ${awrbegintime} ];then
	echo "You must specify parameters:-b for begin time of awr"
	exit 98
fi
if [ -z ${awrendtime} ];then
	echo "You must specify parameters:-e for end time of awr"
	exit 98
fi
if [ -z ${awrname} ];then
	echo "You must specify parameters:-n for report name of awr"
	exit 98
fi
#判断参数为时间
date -d "${awrbegintime:0:8} ${awrbegintime:8:2}" > /dev/null 2>&1
if [ $? -ne 0 ];then
	echo "The valus of -b is invalid date."
	exit 97
fi
date -d "${awrendtime:0:8} ${awrendtime:8:2}" > /dev/null 2>&1
if [ $? -ne 0 ];then
	echo "The valus of -e is invalid date."
	exit 97
fi
############################################
#执行函数,获取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的脚本”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么获取AWR的脚本

本文链接: https://lsjlt.com/news/63943.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么获取AWR的脚本
    本篇内容介绍了“怎么获取AWR的脚本”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!#!/bin/bash ...
    99+
    2024-04-02
  • Shell脚本中怎么获取进程ID
    今天就跟大家聊聊有关Shell脚本中怎么获取进程ID,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在某些情况下,你也许想要知道运行中的子shell的PID。这个PID信息可以在不同的...
    99+
    2023-06-09
  • Shell脚本中怎么获取本机ip地址
    这期内容当中小编将会给大家带来有关Shell脚本中怎么获取本机ip地址,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。方法一:代码如下:/sbin/ifconfig -a|grep inet|grep -v...
    99+
    2023-06-09
  • vbs中怎么获取脚本当前路径
    这篇文章给大家介绍vbs中怎么获取脚本当前路径,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。方法一:currentpath = createobject("Scripting.FileSystemObject...
    99+
    2023-06-08
  • linux中怎么获取shell脚本的绝对路径
    这期内容当中小编将会给大家带来有关linux中怎么获取shell脚本的绝对路径,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。脚本名:a.sh 位置:/tmp/whuang/study/java 脚本内容:...
    99+
    2023-06-13
  • 获取sql完整脚本,get_fulltext.sh
    点击(此处)折叠或打开 ...
    99+
    2024-04-02
  • 怎么在Linux脚本中获取当前时间
    在Linux脚本中获取当前时间可以使用内置的date命令。该命令可以显示当前日期和时间,您可以将其输出保存到变量中以在脚本中使用。 ...
    99+
    2024-04-02
  • 如何获取完整的sqltext脚本
    这篇文章给大家分享的是有关如何获取完整的sqltext脚本的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 #!/bin/bash # by ray # 2017-08-31...
    99+
    2024-04-02
  • 怎么用Shell脚本获取进程的运行时间
    这篇文章主要介绍“怎么用Shell脚本获取进程的运行时间”,在日常操作中,相信很多人在怎么用Shell脚本获取进程的运行时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shell脚本获取进程的运行时间...
    99+
    2023-06-09
  • 怎么用Linux shell脚本获取外网IP地址
    本篇内容介绍了“怎么用Linux shell脚本获取外网IP地址”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!基于Linux系统的获取外网I...
    99+
    2023-06-27
  • 获取shell脚本自身所在目录的Shell脚本分享
    前几天写的七牛的参赛demo,用bash写了一个便捷安装的脚本,涉及到了路径相关的判断,从stackoverflow,加上自己的实践整理一下。 简单版 下面是一个最简单的实现,可以解决大多数问题,缺陷是对于...
    99+
    2022-06-04
    脚本 目录 shell
  • 如何获取shell脚本自身所在目录的Shell脚本
    这篇文章主要讲解了“如何获取shell脚本自身所在目录的Shell脚本”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何获取shell脚本自身所在目录的Shell脚本”吧!简单版下面是一个最...
    99+
    2023-06-09
  • Shell中中怎么获取脚本目录的绝对路径
    Shell中中怎么获取脚本目录的绝对路径,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。要得到正在执行的程序/脚本自身所存放的绝对路径,在 PHP 里面可以用 dirname...
    99+
    2023-06-09
  • Shell脚本中怎么获取本地网卡IP和mac地址
    这篇文章将为大家详细讲解有关Shell脚本中怎么获取本地网卡IP和mac地址,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。#/usr/bin/env bash# Name...
    99+
    2023-06-09
  • 使用Python脚本获取CPU温度
    不同的linux发行版可能获取CPU温度文件的目录不所不同,可自行百度。 # fedora filepath :'/sys/class/hwmon/hwmon0/device/hwmon/hwmon0/temp2_input' #...
    99+
    2023-01-31
    脚本 温度 Python
  • Shell脚本获取进程的运行时间
    在我们的系统中,我曾写了一个脚本去定时更新一些repository,但偶尔会遇到问题,比如:git pull之时可能会卡在那里(可能由于某时刻的网络问题),它会阻碍后面的下一次更新。所以我就在想,我今后启动...
    99+
    2022-06-04
    脚本 进程 时间
  • Shell脚本中获取进程ID的方法
    提问: 我想要知道运行中脚本子shell的进程id。我该如何在shell脚本中得到PID。 当我在执行shell脚本时,它会启动一个叫子shell的进程。作为主shell的子进程,子shell将shell脚...
    99+
    2022-06-04
    脚本 进程 方法
  • 【Redis】获取没有设置ttl的key脚本
    一 前言       在运维Redis的时候,总会遇到使用不规范的业务设计,比如没有对key设置ttl,进而导致内存空间吃紧,通常的解决方法是在slave上du...
    99+
    2024-04-02
  • Python脚本获取操作系统版本信息
    查看系统版本信息是一件家常便饭的事情,有时候需要将版本信息录入到资产管理系统中,如果每次手动的去查询这些信息再录入系统那么是一件令人呢头疼的事情,如果采用脚本去完成这件事情,那么情况就有所不同了。 在Pyt...
    99+
    2022-06-04
    脚本 操作系统 版本
  • 怎么在Linux中使用Shell脚本获取终端宽度
    这篇文章给大家介绍怎么在Linux中使用Shell脚本获取终端宽度,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。获取终端大小时候的学习在写shell脚本时想输出一行占满整个终端屏幕宽度的 横杠 发现for循环会导致执行...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作