【Shell脚本】根据起止日期获取Alert日志内容

【Shell脚本】根据起止日期获取Alert日志内容

根据输入的起止日期字符串,检索Oracle告警日志,打印中间的日志行内容。

bash 复制代码
#!/bin/bash
# $1 START_TIME_STR, e.g. "Oct 17 07:" 
# $2 END_TIME_STR, e.g. "Oct 17 08:"
source /home/oracle/.bash_profile
FILEPATH="$ORACLE_BASE/diag/rdbms/`hostname`/${ORACLE_SID}/trace/alert_${ORACLE_SID}.log"

retrieveLog()
{
  #echo $1,$2,$3
  lineStart=`grep -n "$1" "$3" | awk -F":" '{print $1}' | head -n1`
  lineEnd=`grep -n "$2" "$3" | awk -F":" '{print $1}' | tail -n1`

  echo "lineStart is ${lineStart}, lineEnd is ${lineEnd}."

  if [ -z "${lineStart}" ] || [ -z "${lineEnd}" ]
  then 
    echo "lineStart and lineEnd cannot be empty!"
  else
    echo "Retrieving the required log ..." 
    echo "########################################################"
    sed -n "${lineStart},${lineEnd}p" $3
    echo "########################################################"
    echo "Finished retrieving the required log ..."
  fi 
}

if [ -f "$FILEPATH" ]
then
  retrieveLog "$1" "$2" "$FILEPATH"
else
  echo "$FILEPATH does not EXIST! Please input the absolute log path."
  read -p "请输入日志文件路径: " LOGPATH
  retrieveLog "$1" "$2" "$LOGPATH"
fi
相关推荐
武昌库里写JAVA3 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
老虎06274 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle
Mr. zhihao7 小时前
SQL LEFT JOIN 与 WHERE 条件的隐藏坑
数据库·sql
silver98868 小时前
sql链接的url中serverTimezone的作用
数据库·sql
sleetdream10 小时前
Flink Sql 按分钟或日期统计数据量
sql·flink
Apple_羊先森11 小时前
Oracle数据库操作深入研究:备份、数据删除与性能优化
数据库·oracle·性能优化
一宿君13 小时前
Github 9 个惊艳的开源 NL2SQL 项目
sql·nlp·github
吃掉你也没关系吧1 天前
【postgresql】一文详解postgresql中的统计模块
sql·postgresql
AI 嗯啦1 天前
SQL详细语法教程(三)mysql的函数知识
android·开发语言·数据库·python·sql·mysql
好记忆不如烂笔头abc1 天前
另类pdb恢复方式-2
oracle