如何将一shell脚本中的每一步命令执行结果输出到指定日志文件中

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何将一shell脚本中的每一步命令执行结果输出到指定日志文件中相关的知识,希望对你有一定的参考价值。

参考技术A 执行shell脚本重定向
test.sh 2>&1 >test.log本回答被提问者采纳

linux的shell编程中如何将一段命令的结果封装成一个变量?

比如我创建一个test.sh文件
文件中有一段是dmesg | grep eth 我如何将这段命令的结果封装成一个变量
变量名自拟

直接赋值给变量就可以了啊,变量可以保存多行字符串内容的。使用变量的时候记得将其放在双引号里就行了。

var=`dmesg | grep eth`
echo "$var"

一对反引号(ESC下面的键),表示优先执行其中的命令,执行完成后将结果赋值给var变量。

字符串变量使用的时候加双引号,作为一个整体看待。

参考技术A [root@YYStorage2 ~]# cat test.sh

#!/bin/sh
dmesg|grep $1

[root@YYStorage2 ~]# chmod +x test.sh

[root@YYStorage2 ~]# ./test.sh eth

e1000: eth0: e1000_probe: Intel(R) PRO/1000 Network Connection

e1000: eth0 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: None

eth0: no IPv6 routers present

ADDRCONF(NETDEV_UP): eth0: link is not ready

e1000: eth0 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: None

ADDRCONF(NETDEV_CHANGE): eth0: link becomes ready

eth0: no IPv6 routers present

e1000: eth0 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: None

eth0: no IPv6 routers present


解释一下吧:在shell中的变量有$?,$1...$9

$1代表第一个变量,$2代表第二个,依次类推,一直到$9

参考技术B

至少有两种方式:

     命令放在``中 (一般键盘1左边那个键),如

    echo `dmesg | grep eth`

    命令放在$()中,如

    echo $(dmesg | grep eth)

参考技术C 可以如下保存到变量varname中
varname=`dmesg | grep eth`
如果返回的是多行,可以保存到数组中
array=($(dmesg | grep eth))
然后用for循环获取数组中各个值
len=$#array[@]
for((i=0; i<$len; i++))
do
oneline=$array[$i]
done
参考技术D var=`ls -l *.* | wc -l`

var=$(ls -l *.* | wc -l)

以上是关于如何将一shell脚本中的每一步命令执行结果输出到指定日志文件中的主要内容,如果未能解决你的问题,请参考以下文章

Shell脚本的调试方法

Shell脚本的调试方法

Linux——shell脚本编程2

shell脚本怎么显示所执行的每一条命令

linux shell脚本,怎样变量传递执行结果

shell 脚本常用调试方法