shell脚本实现监控shell脚本的执行流程及变量的值(shell脚本实现监控进程)

admin3年前网络知识42

很多时候,我们都会写shell程序来完成一些不用重复造轮子的时刻,但是,又因为shell语句中也会有函数,也会有变量,在运行后到底执行了哪些相关的操作,就需要对具体执行过程中的变量等可变的因素的监控,那么我们下面就写个小小的shell例子,来完成这个对执行过程中条件语句中的变量的变化的监控和整个程序的执行流程的观察。

shell程序代码:
复制代码 代码如下:
#!/bin/bash
function setlogfile
{
    if ! [ -z "$1" ]; then
        echo "logfilename is not empty!" >> kthh
        exec 2>> $1
        exec 1>> $1
    fi   
}

num1=$1
logfile=$2
execlogfile=$3

setlogfile ${execlogfile}
set -x
if [ $num1 -eq 0 ]; then
    echo "num1 is 0">> ${logfile}
elif [ $num1 -ge 0 ]; then
    echo "num1 is grate 0">> ${logfile}
else
    echo "num1 is less 0">> ${logfile}
fi
/sbin/shutdown -k 10
if [ $num1 -eq 0 ]; then
    echo "num1 is 0 again">> ${logfile}
fi

在命令行中执行:
复制代码 代码如下:
[root@UFO shellprogram]# ./testexecutelog.sh 0 msglog execlog

在以上的shell脚本程序中 num1对应的值为命令行中的0  logfile的值为msglog  execlogfile的值为execlog。

函数 setlogfile的使用为 setlogfile 日志文件名,在例子中的使用setlogfile ${execlogfile},函数中的exec 2>> $1;exec 1>> $1表示把标准输出和标准错误输出的信息都重定向到execlog文件中。

下面我们来看看execlogfile中的内容,就可以看到shell程序的执行流程和执行过程中的变量的值的变化。
复制代码 代码如下:
[root@UFO shellprogram]# cat execlog
+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0'
+ /sbin/shutdown -k 10
美国高防vps+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0 again'

可见,程序中的流程是和./testexecutelog.sh后的第一个参数决定的。你还可以把第一个参数改为大于0的或小于0的值进行测试。

其中,最重要的一句是set -x,此句的含义为:在每个简单命令被扩展之后,显示PS4扩展值,之后是要执行的命令 。 若不执行这句,则不会将执行中变量的实际值打印到execlog中。有关set的使用可man set了解更多。

注意:exec 在对文件描述符进行操作的时候,也只有在这时,exec 不会覆盖你当前的 shell 环境。也即是不会启动个新的进程。

本文从互联网转载,来源地址:www.inhv.cn/linux-shell/171156.html,原作者保留一切权利,若侵权或引用不当,请联系测速网(inhv.cn)删除。【测速网,优质云服务器提供商】

《shell脚本实现监控shell脚本的执行流程及变量的值(shell脚本实现监控进程)》来自互联网同行内容,若有侵权,请联系我们删除!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

ipad死机打不开

ipad死机打不开的原因有:1、跟用户操作有关,比如下载太多软件或者游戏导致机器占用内存过高死机。2、ipad死机还有可能是长时间玩游戏,导致cpu温度过高,触发了系统自动保护而死机。3、下载的软件与...

双下划线怎么设置

以wps文字为例,先用鼠标框选要添加双下划线的文字。点击word2016“开始”选项卡中下划线按钮右侧的小箭头。点击小箭头后会弹出下划线样式菜单,点击其中的双下划线。这样,之前选择的文字就添加双下划线...

Linux命令cut用法

cut是一个选取命令,就是将一段数据经过分析,取出我们想要的。一般来说,选取信息通常是针对“行”来进行分析的,并不是整篇信息分析的。(1)其语法格式为:cut  [-bn] [file] 或...

戴尔电脑摄像头打不开怎么回事

以戴尔电脑Win10为例,摄像头打不开是因为电脑禁用了摄像头功能,建议到控制面板里开启此功能即可,或者是电脑摄像头硬件损坏,建议售后服务解决。戴尔(Dell),是一家总部位于美国德克萨斯州朗德罗克的世...

WPS图片怎么居中

以WPS为例,图片居中设置只需要在开始选项卡下单击居中按钮即可。 WPS for Android是WPS Office的安卓版,WPS Office是一款办公软件套装,可以实现办公软件最常用的文字、表...

wps为什么不能输入文字

wps不能输入文字的原因是:1、单元格被保护,找到上方菜单栏审阅,查看工作表是否受保护,点击保护工作表取消保护即可。2、字体为白色,实际上是打出字体,因字体与背景色相同而导致无法辨认,将字体改为黑色即...