【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
相关推荐
不会写DN6 分钟前
GORM 实战入门:从环境搭建到企业级常用特性全解析
sql·mysql·go·gin
星如雨グッ!(๑•̀ㅂ•́)و✧4 小时前
Spring WebFlux 中的并发
java·spring·oracle
gjc5925 小时前
如何写好SQL:企业内训文档
数据库·sql
数据库小组6 小时前
Oracle 上云 / 替代场景下,NineData 完成到 PostgreSQL 的低风险迁移
大数据·数据库·mysql·postgresql·oracle·数据一致性·数据库迁移
代码派7 小时前
SQL 审核解决了部分问题,另一部分是慢 SQL 治理
数据库·sql·mysql·数据库管理工具·ninedata·sql审核·sql治理
qq_366086227 小时前
MyBatis 动态 SQL 高频性能优化方案
sql·性能优化·mybatis
不会编程的崽8 小时前
ShowCtf Web14 --不会编程的崽
sql·web
麦聪聊数据8 小时前
基于 SQL2API 架构快速发布 RESTful 接口
数据库·后端·sql·低代码·restful
jnrjian9 小时前
expdp 指定的表分区 其实指定where 条件也可以
oracle
IT邦德9 小时前
Oracle 26ai 图数据库
数据库·oracle