Shell脚本中如何将所有命令执行的结果定位到日志中

经常会有人问:Shell中如何将自己的脚本中的每条命令的执行结果放置到自定义的日志文件中? 默认情况下,每条命令执行后,标准输出会定向到屏幕输出,标准错误也会定向到屏幕输出,但屏幕一晃而过,你也就看不到了,如果使用>或者>>,即重定向或者追加重定向是可以将每条命令的输出定位到日志文件中的,但是要将所有的命令的输出结果定向到一个文件就必须每条命令重定向一次,非常之不方便!使用tee命令不过是,定位,追踪代码的时候方便。还是达不到目的,这个时候使用exec命令非常方便。

比如:

#!/bin/bash
set -xv
exec 1>mylog 2>&1
free
df -h
pwd

第一行是shebang,告诉shell便器使用/bin目录的bash来编译脚本。

第二行是打开模式开关 -v:显示shell所读取的输入值。-x:执行指令后,会先显示该指令及所下的参数

第三行exec命令用于调用并执行指令的命令。

  • exec命令通常用在shell脚本程序中,可以调用其他的命令
  • 1> mylog  是将标准输出重定向到mylog文件中
  • 2>&1 是将标准错误定向到标准输入,一起定向到mylog中,也就是说,标准输入和标准输出都会到mylog文件中

执行上面的脚本后,就会将后面三条命令free, df -h, pwd命令的执行结果全部生产到mylog文件中,也就达到了将所有命令执行结果保存到一个文件的目的,非常之方便!




  • 7
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 你可以使用`which`命令来检查一个命令是否存在。如果命令不存在,`which`命令将不会返回任何内容。例如: ``` which command_name ``` 如果命令存在,`which`命令将会返回命令的完整路径。如果命令不存在,`which`命令将不会返回任何内容。 另外,你也可以使用`type`命令来查看命令的类型。如果命令不存在,`type`命令将会输出一个错误信息。例如: ``` type command_name ``` ### 回答2: Shell脚本是一种编程语言,可以用来编写一系列命令,以达到自动化、自定义和简化工作流程的目的。在编写Shell脚本时,我们需要保证命令的正确性,但有时候会因为疏忽或者其他原因出现错误的命令。 为了查询Shell脚本的错误命令,可以使用Shell解释器的语法检查工具。常见的Shell解释器有Bash、Zsh、Ksh等。以Bash为例,可以使用bash的`-n`参数来进行语法检查,如下所示: ```shell bash -n script.sh ``` 其,`script.sh`是待检查的Shell脚本文件。使用`-n`参数可以告诉bash解释器仅对脚本进行语法检查而不执行。如果脚本存在错误的命令或语法错误,解释器会返回相应的错误信息,帮助我们定位问题所在。 除了使用解释器进行语法检查,还可以根据错误提示和日志来查询错误的命令。当脚本执行时,命令执行的结果通常会被打印到终端或输出到日志文件。通过仔细观察输出日志,我们可以找到错误的命令和相关信息,进而进行查询和修复。 总结来说,在Shell脚本查询错误的命令可以通过使用解释器的语法检查工具来进行检查,同时可以根据错误提示和输出日志来进行查询和定位。这些方法可以帮助我们及时发现和纠正Shell脚本的错误,提高脚本的正确性和可靠性。 ### 回答3: Shell脚本是一种编程语言,可以用于自动化任务和命令执行。在Linux或Unix系统,当我们在Shell脚本执行命令时,有时候会遇到错误的命令。我们可以使用一些方法来查询并处理这些错误的命令。 一种常见的方法是使用条件语句和错误输出重定向来检查命令是否执行成功。我们可以使用`$?`变量来获取上一个命令的返回状态。如果这个值为0,表示命令执行成功;如果不为0,表示命令执行失败。我们可以将这个值与0进行比较,如果不等于0,则表示命令执行失败,我们可以输出错误信息或采取适当的处理措施。 另一种方法是使用`-e`选项,这个选项可以使得当一条命令失败时,整个Shell脚本就会立即停止执行。我们可以在Shell脚本的开头添加`set -e`来启用这个选项。这样,当遇到执行失败的命令时,Shell脚本就会立即退出,我们可以根据需要选择是否输出相应的错误信息。 除了以上方法,我们还可以使用`trap`命令来设置一个信号处理程序。当Shell脚本执行过程出现错误时,可以通过设置一个信号处理程序来进行处理。我们可以使用`trap '处理代码' ERR`来设置一个错误处理程序,当出现错误时,就会执行相应的处理代码。 总结起来,查询错误的命令主要可以通过条件语句和错误输出重定向、使用`-e`选项、以及使用`trap`命令来进行处理。这些方法可以帮助我们在Shell脚本查询错误的命令,并采取相应的处理措施。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值