如何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
如何根据条件输出MySQL表Insert行?

1 前言 一个问题,一篇文章,一出故事。 笔者执行NextCloud的维护任务,需要从数据表中删除用 …

Bash
如何函数代替Base Shell的命令别名?

1 前言 一个问题,一篇文章,一出故事。 之前的章节我们使用命令别名来缩写输入的命令,相见如下, 如 …

Bash
如何监视服务并自动通知?

1 前言 一个问题,一篇文章,一出故事。 最近笔者希望通过脚本实现监视服务并在服务异常是使用两种方式 …