如何Linux Shell截取日志文件?

Bash

1 前言

一个问题,一篇文章,一出故事。
笔者最近使用Linux Shell截取日志文件。
由于有的文件会随时有新的日志写入且如果文件被直接重命令会导致日志写入失败。即日志文件不适宜直接删除且需要实现日志文件另存,于是整理此Shell处理逻辑。

2 最佳实践

2.1 截取日志的步骤

2.1.1 取得文件的最后行号

wc -l < /var/log/messages

以上以“/var/log/messages”为范例,执行后可见如下输出,

3615

2.1.2 根据最后行号另存文件

head -n 3615 /var/log/messages > /var/log/messages.save

2.1.3 删除已经另存的文件内容

sed -i -e "1,3615d" /var/log/messages

2.2 截取日志脚本范例

#!/bin/bash

logFile="/var/log/messages"
fileEnd=`wc -l < "$logFile"`
head -n "$fileEnd" "$logFile" > "$logFile"'.save'
sed -i -e "1,${fileEnd}d" $logFile
没有评论

发表回复

Bash
如何在远程主机执行函数?

1 前言 一个问题,一篇文章,一出故事。 笔者今天想在远程机器执行本地脚本定义的函数,于是整理当前章 …

Bash
如何实现监视多台服务器的日志?

1 前言 一个问题,一篇文章,一出故事。 今天遇到需要根据PostFix的特定邮箱地址触发一个电话报 …

Bash
如何用Base Shell推送华为消息?

1 前言 一个问题,一篇文章,一出故事。 今天遇到服务器推送华为消息失败,于是尝试使用curl去测试 …