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

admin3年前网络知识19

很多时候,我们都会写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脚本实现监控进程)》来自互联网同行内容,若有侵权,请联系我们删除!

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

相关文章

wps会员可以共享几个人

wps会员不可以同时共享几个人,因为WPS的会员是有单点登录和异地登录控制的,只可以在同一台电脑上登录。WPS Office是由金山软件股份有限公司自主研发的一款办公软件套装,可以实现办公软件最常用的...

ai文件怎么打开

什么是AI文件AI文件是指Adobe Illustrator文件,是一种矢量图形文件格式,由Adobe Illustrator软件创建和编辑。这种文件格式可以存储一些高质量的矢量图形元素,如线条、形状...

word等宽两栏怎么设置

以word2007版为例,word等宽两栏的设置方法是:1、打开电脑找到并点击word2007版新建工作文档软件;2、双击打开word文档软件以后,在界面的上方找到并点击页面布局下的”分栏“命令;3、...

cad选不中对象怎么办

CAD中选中的对象不显示被选中的原因可能是系统错误导致的,建议先退出再重新进入试试。CAD(Computer Aided Drafting)诞生于60年代,是美国麻省理工大学提出了交互式图形学的研究计...

windows7回收站是什么区域

windows7回收站是硬盘上的一块区域,回收站是一个特殊的文件夹,默认在每个硬盘分区根目录下的RECYCLER文件夹中。硬盘(英语:Hard Disk Drive,缩写:HDD)是计算机上使用的以旋...

抖音如何提高播放量

抖音提高播放量的方法如下:1、坚持做原创视频原创的视频代表了作者的风格,蕴含了作者的思想和态度。是最能体现作者特质的东西。所有的平台都鼓励原创,抖音也不例外,而且做原创可以培养一批忠实粉丝,为今后的壮...