使用set命令完善shell脚本

在Linux中编写Shell脚本,当脚本中有命令执行失败,我们又没有写相对于的判断条件时,脚本并不会向其他语言一样自动退出,而是忽略执行失败的命令继续向下执行,这可能会导致很多错误,增加我们排错的难度、浪费我们的时间。

那是不是我们就只能对每一条可能执行出错的命令使用$?进行条件判断呢?当然不是,在脚本编写中。我们可以在文件开头写上

set -e

这代表着在脚本中有命令执行失败时退出程序,避免继续执行错误的操作。例如:

$ cat test.sh
#!/bin/bash

set -e # 开启退出模式

cp /tmp/foo /tmp/bar # 假设/tmp/foo不存在,这个命令会失败

echo "Copy successful" # 这个语句不会执行,因为上一个命令已经退出了

$ bash test.sh 
cp: cannot stat '/tmp/foo': No such file or directory 

set命令是Linux系统中的一个内置变量,用来设置和取消设置shell变量和选项,。它通常用在shell脚本中,用来配置环境和控制脚本的行为。常见的用法除了上述的set -e外,还有以下几点:

  • -x选项可以显示每一行脚本执行时的命令和参数,跟sh -x相同,用于调试脚本。例如:

    $ cat test.sh
    #!/bin/bash
    
    echo "Hello World"
    $ bash -x test.sh
    + echo 'Hello World'
    Hello World
    
  • -a选项可以让你创建的任何变量或函数自动导出,让子shell和脚本也能使用它们。例如:

    $ cat test.sh
    #!/bin/bash
    
    set -a # 开启导出模式
    
    foo=bar
    
    set +a # 关闭导出模式
    
    baz=qux
    
    echo $foo $baz # 在脚本中输出变量值
    
    $ bash test.sh
    bar qux # 脚本输出结果
    $ echo $foo $baz # 在当前shell中输出变量值
    
    bar  # 只有foo被导出了,baz没有被导出
    

set也能定义变量,跟export类似,但不同的是set只定义当前shell的变量,而export是定义环境变量。例如:

$ set foo=bar
$ echo $foo
bar
$ bash # 开启一个子shell
$ echo $foo

$ exit # 退出子shell
$ export foo=bar # 用export指令定义变量
$ bash # 开启一个子shell
$ echo $foo
bar

你可能感兴趣的:(shell,bash,linux,运维)