Linux shell tail -f如何自动终止

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux shell tail -f如何自动终止相关的知识,希望对你有一定的参考价值。

Linux shell脚本里需要 tail -f a.file,当搜索到关键字之后自动停止tail命令,继续执行shell脚本里tail之后的命令,该如何实现
这是我这边的方法,你们有更好的方法,欢迎贴出来

tail -f $DIR/a.file|while read line
do
a=`echo $line|grep "*****"|wc -l`
if [ $a -lt 1 ];then
echo $line
else
break
fi

done

命令是::wq  保存文件并退出vi!

要明白有3种模式,命令行模式(ESC进入),插入模式(i进入),底行模式(:进入)。一般编辑完文档后,先按ESC退出插入模式,然后在底行输入:x来保存退出。

其他命令:

:w保存文件但不退出vi:w file 将修改另外保存到file中,不退出vi:w!强制保存,不推出vi:wq  保存文件并退出vi:wq! 强制保存文件,并退出viq:  不保存文件,退出vi:q! 不保存文件,强制退出vi:e! 放弃所有修改,从上次保存文件开始再编辑。

扩展资料:

linux常用命令及技巧

ubuntu常用命令:

1、dpkg: package manager for Debian

安装: dpkg -i package

卸载: dpkg -r package

卸载并删除配置文件: dpkg -P |--purge package

如果安装一个包时、说依赖某些库、 可以先 apt-get install somelib

查看软件包安装内容 :dpkg -L package

查看文件由哪个软件包提供: dpkg -S filename

另外 dpkg还有 dselect和aptitude 两个frontend

2、 apt

安装: apt-get install packs

更新源:apt-get update

升级系统:apt-get upgrade

智能升级、安装新软件包,删除废弃的软件包:apt-get dist-upgrade

f --fix broken 修复依赖:apt-get -f install

自动删除无用的软件:apt-get autoremove

删除软件:apt-get remove packages

清除所以删除包的残余配置文件: dpkg -l |grep ^rc|awk 'print $2' |tr ["/n"] [" "]|sudo xargs dpkg -P

参考资料来源:百度百科-linux

参考技术A 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的作用是防止上一次日志的结尾对本次打印产生影响

参考技术B 如果找到关键字,停止tail,继续执行后面的,但如果没找到的情况你没讲,我这个是如果超时1分钟没找到,也停止tail,并且终止脚本继续执行。

 sed /"$keywords"/q; kill $!;  < <(exec timeout 1m tail -Fn 0 "$log_file")

适合用在脚本中,$keywords 和 $log_file 是要查找的关键字和目标文件,替换掉或者脚本前面设置变量。

这个命令用到了进程替换(bash相关),和遇到错误停止(凡是脚本都应该用),所以脚本开头得是这两行 

#!/bin/bash
set -euxo pipefail

并且执行这个脚本也得用 bash xxxx.sh,虽然CentOS里 sh 是 bash 的软链,但也不能用 sh,得用 bash

参考技术C 如下,以create.log问日志文件,BUILD SUCCESSFUL为关键字

#!/bin/bash
num=1
while [ $num -le 10 ]
do
echo $num
CHECK_RESULT=`cat /app/aideploy/deploy_ncrm_fb/bin/log/create.log | grep 'BUILD SUCCESSFUL' | wc -l`
echo "The check results: "$CHECK_RESULT
if [ $CHECK_RESULT -eq 1 ]; then
echo "BUILD SUCCESSFUL"
exit 0
else
sleep 10
fi
let num++
done
echo "BUILD FAILTURE"
exit 1
参考技术D 判断下如果真就中断,继续执行后面的,

Linux基础shell脚本题

1、编写脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和 

解:vim /root/bin/sumid.sh

#!/bin/bash

tenuser=`cat /etc/passwd | head -n10 | tail -n1 |cut -d: -f3`

twentyuser=`cat /etc/passwd | head -n20 |tail -n1 | cut -d: -f3`

let sum=$[tenuser+twentyuser]

echo "The tenuser and twentyuser finally is $sum"


2、编写脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和 

解:vim /root/bin/sumspace.sh

#!/bin/bash

first=`cat $1 | grep "^[[:space:]]*$" | wc -l`

second=`cat $2 | grep "^[[:space:]]*$" | wc -l`

let sum=$[first+second]

echo $sum


3、编写脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录中共有多少个一级子目录和文件

解:vim /root/bin/sumfile.sh

#!/bin/bash

first=`ls -l /etc | egrep "(^d.*)|(^-.*)" | wc -l`

second=`ls -l /var | egrep "(^d.*)|(^-.*)" | wc -l`

third=`ls -l /usr | egrep "(^d.*) | (^.*)" | wc -l`

let sum=$[first+second+third]

echo $sum


4、编写脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果


参数个数不小于1,则显示第一个参数所指向的文件中的空白行数

解:vim /root/bin/argsnum.sh

#!/bin/bash

[ "$#" -lt 1 ] && echo "The must one arg" && exit 20

[ -e $1 ] || { echo "No such file or directory" && exit 30; }

[ "$#" -ge 1 ] && echo "The blankspace is `grep "^[[:space:]]*$" $1 | wc -l`"


5、编写脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如


果不可ping通,则提示用户“该IP地址不可访问” 

解:[[ ! $1 =~ (([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]) ]] 


&& echo "please print right ip format!" && exit 20

`ping $1 -c1 &>/dev/null` && echo "Yes" || echo "No"


6、编写脚本/root/bin/checkdisk.sh,检查磁盘分区空间和inode使用率,如果超过80%,就发广播警告空间将满

解:vim /root/bin/checkdisk.sh

disk=`df -h | grep /dev/sd | tr -s " "  % | cut -d % -f5 | sort -nr | head -n1`

inode=`df -i | grep /dev/sd | tr -s " " % | cut -d % -f5 | sort -nr | head -n1`

[ "$disk" -gt 80 ] && echo "The disk is "$disk"% will man" ||  echo The disk size is "$disk"% 

[ "$inode" -gt 5 ] && echo The inode is "$inode"% man  || { echo The indoe size is "$inode" && exit 30; }


7、编写脚本/bin/per.sh,判断当前用户对指定的参数文件,是否不可读并且不可写

解:vim /bin/per.sh

#!/bin/bash

[ ! -r "[email protected]" ] && [ ! -w "[email protected]" ] && echo The "[email protected]" is Not have w and r permisson or have some one permisson || echo The "[email protected]


have w and r permission

#另一种写法

[ ! \( -r "[email protected]" -a -w "[email protected]" \) ] && echo The "[email protected]" is Not have w and r permisson or have some one permisson || echo The "[email protected]


have w and r permission


8、编写脚本/root/bin/excute.sh ,判断参数文件是否为sh后缀的普通文件,如果是,添加所有人可执行权限,否则提示用户非脚本文件 

解:vim /root/bin/excute.sh

[[ "[email protected]" =~ .*\.sh ]] && `chmod a+x "[email protected]" ` || echo The "[email protected]" is not script file



9、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统

解:vim /root/bin/nologin.sh

#!/bin/bash

touch /etc/nologin

echo "disabled common user login"


vim /root/bin/nologin.sh

#!/bin/bash

rm -rf /etc/nologin

禁止普通用户登录时执行第一个脚本,允许登录后执行第二个脚本


10、编写脚本/root/bin/agree.sh,提示用户输入各种各样的Yes或No都可以,输入错误的话提示"请输入正确选项"

解:vim /root/bin/agree.sh

#!/bin/bash

read -p "Do you agree,Plase print Yes or No: " ANS(#变量名)

[[ "$ANS" =~ [Yy]|[Yy][Ee][Ss]|[Nn][Oo]|[Nn] ]] || { echo "please input right options" && exit 20;}


11、让所有用户的PATH环境变量的值多出一个路径,例如:/usr/local/apache/bin

解:vim /etc/profile

PATH=$PATH:$HOME/bin:/usr/local/apache/bin

source /etc/profile


12、用户root登录时,将命令指示符变成红色,并自动启用如下别名:

rm=‘rm –i’ 

cdnet=‘cd /etc/sysconfig/network-scripts/’ 

editnet=‘vim /etc/sysconfig/network-scripts/ifcfg-eth0’ 

editnet=‘vim /etc/sysconfig/network-scripts/ifcfg-eno16777736 或 ifcfg-ens33 ’ (如果系统是CentOS7) 

解:vim ~/.bashrc

rm='rm –i'

cdnet='cd /etc/sysconfig/network-scripts/'

editnet='vim /etc/sysconfig/network-scripts/ifcfg-ens33'

export PS1='\[\e[1;31m\][\[email protected]\h \W]\$\[\e[0m\]'


source ~/.bashrc


13、任意用户登录系统时,显示红色字体的警示提醒信息“Hi,dangerous!” 

解:vim /etc/profile.d/danger.sh

#!/bin/bash

echo -e "\033[1;5;31mHi,dangerous!\033[0m"


14、编写生成脚本基本格式的脚本,包括作者,联系方式,版本,时间,描述等

解:vim /root/bin/createscript.sh

#!/bin/bash

touch $1

chmod +x $1

echo "#/bin/bash

#*************************************

#Filename:                    $1

#Author:                      Fang

#Date:                     `date "+%Y-%m-%d %H:%M:%S"`

#*************************************" > $1

vim + $1


以上是关于Linux shell tail -f如何自动终止的主要内容,如果未能解决你的问题,请参考以下文章

Linux基础shell脚本题

shell编程中的sed问题

LINUX SHELL

SSH Secure Shell显示serverTomcat后台内容

Linux用户和组管理类命令

使用shell脚本监控Linux主机