Linux shell tail -f如何自动终止

Linux shell tail -f如何自动终止,第1张

tail -fn 0 --pid=`ps uxh|grep 'sed[[:space:]]\/startup'|awk '{print $2}'|sort -nr|head -1` xxx.log|sed /startup[[:space:]]in/Q

#解释:

#1、sed /startup[[:space:]]in/Q,执行命令,查找字符串'startup in',也可以换成其他正则表达式来匹配,Q代表查到后退出sed

#2、--pid参数,检测某一个pid,当检测到pid停止的时候,停止tail

#3、ps uxh查询当前用户的进程

#4、grep 'sed[[:space:]]\/startup'查找1里面执行的sed的进程,如果关键字不是startup的话,这里也需要进行更换

#5、awk '{print $2}'获取每行结果的第二个词,也就是pid

#6、sort -nr将结果进行倒序排序

#7、head -1取第一个结果,取最大的pid

#8、从3到7执行过后,取到的pid大致可以认定为1里面sed的pid

#9、tail -fn 0 --pid=`...` xxx.log,pid等号后的 ` 不是引号,是ESC下面那个按键,其中-n 0的作用是防止上一次日志的结尾对本次打印产生影响

原单词 tail (尾巴)

<mark style="box-sizing: border-boxbackground-color: rgb(255, 255, 0)color: rgb(0, 0, 0)">工作中应用于查看实时日志,或者复现BUG时实时查看日志</mark>

tail 命令可用于查看文件的内容,与cat不同的是tail命令是从末尾开始查看,默认查看最后十行,最常用的是 -f 参数,可以实时刷新文件的内容(循环读取)

-f: 循环读取

-n<行数>: 显示文件的尾部n行内容

例子:

tail a.log

读取a.log最后10行内容

tail -f a.log

循环读取a.log的内容

tail -n50 a.log

读取a.log最后50行内容

tail -50f a.log

读取a.log最后50行内容,并循环读取新的内容

进入/root目录

新建 tailTest文件夹

进入 tailTest目录

新建 a.log 文件

将 / 根目录下的内容 重定向到 a.log

ls / >a.log

tail a.log

tail -n5 a.log

第一步: 双击 图中菜单

第二步 : 拖拽新的窗口

第三步 : 获得下图所示的 界面

在左侧窗口中 输入 tail -f a.log

在右侧窗口中输入 ll /root/ >>/root/tailTast/a.log (将/root 目录下的文件详情 追加到 a.log文件中)

可以看到左侧窗口 自动出现了追加的内容

这就是 tail -f 参数的作用: 实时读取文件的新内容(或者叫循环读取), 通常我们用 tail -f 命令来查看 服务端打印的日志

但是这个时候 左侧窗口的 tail -f a.log命令依旧在执行 ,首先选中左侧窗口,按下 ctrl+c 就可以退出命令

tail -20f a.log

按下 ctrl+c 退出命令

多种方法供选择:

del

ctrl-C

ctrl-X

ctrl-\

ps -ef|grep tail|awk '{print $2}'|xargs -i kill -9 {}

killall

shutdown now

halt

reboot

如果仍然不能结束,只能拔掉电源了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7196316.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存