#解释:
#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
如果仍然不能结束,只能拔掉电源了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)