【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
相关推荐
程序边界16 分钟前
KingbaseES 表空间目录自动创建特性深度解析(下篇)
数据库·oracle
Strugglingler2 小时前
基于whiptail开发shell导航工具
linux·shell·ui设计·whiptail
七夜zippoe2 小时前
DolphinDB SQL查询:从基础到进阶
数据库·sql·进阶·聚合·dolphindb
爪洼传承人4 小时前
AI工具MCP的配置,慢sql优化
android·数据库·sql
Aloudata5 小时前
PL/SQL 存储过程血缘解析指南:攻克数据治理的「最后堡垒」
数据库·sql·数据治理·数据管理·元数据·数据血缘
zgscwxd6 小时前
B审批流程与数据库设计要点
sql
椰猫子6 小时前
数据库(数据库相关概念、MySQL数据库、SQL(DDL、DML、DQL))
数据库·sql·mysql
喵了几个咪7 小时前
MySQL 运维实战:ibd 文件批量转换为 SQL 完整指南(基于 ibd2sql)
运维·sql·mysql
CappuccinoRose7 小时前
关系数据库标准语言(SQL)- 软考备战(三十一)
数据库·sql·软考
山峰哥8 小时前
解锁SQL优化新境界:从索引策略到高效查询实战
数据库·sql·oracle