看完这篇,写的Shell脚本更加健壮了!

[[356512]]

本文转载自微信公众号「编程珠玑」,作者守望先生 。转载本文请联系编程珠玑公众号。  

 如果秉承着能跑就行的态度写shell脚本,是很自在的,但是如果你想要写出健壮,可靠的shell脚本,可没那么容易。那么有什么可操作的经验或者方法吗?

语法检查

第一个最简单的方法就是利用工具对脚本进行检查,这一部分已经在《有了这个神器,再也不怕shell写不对了》中介绍过了,它能最大程度地发现shell脚本中存在的语法错误,如果你还不知道,建议你绝对不要错过。

而为了保证脚本健壮可靠,那么就需要保证脚本在一些特殊的情况及早出现,避免漏网之鱼。来看看有哪些可行的技巧。

脚本失败时即退出

可以在脚本的开头设置如下:

  1. set -e 

举个例子:

  1. #!/bin/bash 
  2. set -e 
  3. lp    #这里运行会出错 
  4. date 

这种情况下,运行一旦出错就会退出,不放过一个问题:

  1. $ ./test.sh 
  2. lp: Error - no default destination available. 

当然了,这也有不好的地方,有时候命令执行本来就可能是失败的,你还是希望它继续,可以临时加上|| true:

  1. #!/bin/bash 
  2. set -e 
  3. lp  || true   
  4. date 

不过个人觉得这样的设置用处不是特别大,因为很多时候就是需要处理不同的错误情况,而这样只能要么遇到错误退出,要么认为正确,导致无法走到异常分支。

通过set +e设置回来:

  1. set -e 
  2. #command 
  3. set +e 
  4. #other command 

打印脚本执行过程

调试阶段,你可能想知道整个过程是执行了哪些命令,每条命令都具体执行了什么,可以利用下面的方式执行:

  1. sh -x test.sh 

或者,和上面类似,在开头加上set -x:

  1. //来源:公众号【编程珠玑】 
  2. //作者:守望先生 
  3. #!/bin/bash 
  4. set -x 
  5. if [ $# -lt 1 ] 
  6. then 
  7.    echo  "no para" 
  8. else 
  9.    echo "para 1 $1" 
  10. fi 

执行时,输出如下:

  1. + [ 0 -le 1 ] 
  2. + echo no para 
  3. no para 

前面带+的内容就是命令实际执行的,你可以看到比较条件是什么,变量被展开成了具体内容,走到了哪个分支,非常清楚。

显示未定义的变量

shell中变量没有定义,仍然是可以使用的,但是它的结果可能不是你所预期的。举个例子:

  1. //来源:公众号【编程珠玑】 
  2. //作者:守望先生 
  3. #!/bin/bash 
  4. if [ "$var" = "abc" ] 
  5. then 
  6.    echo  " not abc" 
  7. else 
  8.    echo " abc " 
  9. fi 

这里本来想判断var的内容是否为abc,实际上var并没有定义,但是在这里使用并没有报错,如果我们想早点发现这类问题,避免在复杂的脚本中问题被掩盖,那么可以在开头加上

  1. set -u 

再次运行就会提示:

  1. test.sh: 5: test.sh: num: parameter not set 

再想象一下,你本来想删除:

  1. rm -rf $dir/* 

然后dir是空的时候,变成了什么?

是不是有种后背发凉的感觉?

管道命令一个失败时整个失败

有时候我们可能会执行类似这样的命令:

  1. cat test.sh |grep if | cut -d ';' -f 2 

三条命令一行执行,如果我们希望在其中一条失败,整个命令就失败,而避免执行后面无意义的命令,那么可以在开始设置:

  1. set -o pipefail 

不设置的情况下,cat test.sh即使执行失败了,后面的grep实际上还会继续执行,可能会导致一些意想不到的情况发生,如果不想这样的情况发生,那么这样设置是有帮助的。

对于静态变量使用readonly

通常我们会在脚本开头定义一些静态变量:

  1. MY_PATH=/usr/bin 

而为了避免MY_PATH被意外修改,可以这样:

  1. readonly MY_PATH=/usr/bin 

这样的话,一旦后面有命令尝试修改,就会报错。

  1. #!/bin/bash 
  2. readonly MY_PATH=/usr/bin 
  3. MY_PATH=/usr/local/bin 

运行一下试试:

  1. $ ./test.sh 
  2. test.sh: 3: test.sh: MY_PATH: is read only 

看,给你提示了!

给变量设置可选的初始值

例如:

  1. name=${1:-shouwang} 
  2. echo "${name}" 

这里让name为$1,即第一个参数,而当它为空时,令name为shouwang。

多条命令执行使用&&

例如:

  1. cmd0;cmd1;cmd1 

这里如果cmd0失败了,后面的命令仍然会执行,而如果不希望后面的命令执行,可以使用:

  1. cmd0 && cmd1 && cmd1 

使用函数

脚本本身比较短还好,而脚本一旦变长,不使用函数,将使得脚本很难维护,可读性也很差。

总结

实际上最开始介绍的脚本检查工具就已经非常有效了,基本的错误都能检查出来,而其他的内容,更多的是关注于脚本调试,不放过任何一个可能的错误。

最后,还是优先推荐shellcheck工具。地址:https://www.shellcheck.net

作者:守望,linux应用开发者,目前在公众号【编程珠玑】?分享Linux/C/C++/数据结构与算法/工具等原创技术文章和学习资源。

原文链接:https://mp.weixin.qq.com/s/EpCoiHHpCdPcj8kkeRjHjw

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/127569.html<

(0)
运维的头像运维
上一篇2025-02-24 17:59
下一篇 2025-02-24 18:00

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注