【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
相关推荐
GreatSQL社区3 小时前
【GreatSQL优化器-15】index merge
数据库·oracle
Warren986 小时前
Springboot中分析SQL性能的两种方式
java·spring boot·后端·sql·mysql·intellij-idea
V1ncent Chen6 小时前
MySQL 插入更新语句(insert…on duplicate key update语句 )
数据库·sql·mysql
web150850966417 小时前
给SQL server数据库表字段添加注释SQL,附修改、删除注释SQL及演示
数据库·sql·oracle
new出对象9 小时前
数据库增删查改sql语句
数据库·sql·oracle
Themberfue9 小时前
SQL ①-数据库 || MySQL
数据库·sql·mysql·数据库系统·数据库管理系统
RisingWave中文开源社区10 小时前
一文详解物化视图(MV):定义、优势和用例
数据库·sql·数据分析
想做富婆11 小时前
数仓搭建实操(传统数仓oracle):[构建数仓层次|ODS贴源层]
数据库·oracle·数仓
limts11 小时前
Oracle中补全时间的处理
数据库·oracle
Jason951013 小时前
使用大语言模型(Deepseek)构建一个基于 SQL 数据的问答系统
数据库·sql·问答系统·大语言模型·deepseek