背景

最近处理一个 bug 很有意思,有客户反馈某个配置文件解析失败了,出错的那行的内容就只有一个字母 a

最开始以为是谁改动了处理的脚本,但要到了问题代码中的脚本,比较发现跟库上是一样的。

又经过一番查找,才发现原来是脚本中的一行 echo 引入的。

问题代码

出问题的那行 bash 脚本是这样, echo 一个字符串到某配置文件中。

echo [partition] >> xxx.config

这行平平无奇的代码在大多数人的环境下,确实是正常运行的,但某些情况下会出 bug,那就是当运行脚本的目录下存在特定文件的时候。

复现问题

看看例子,就明白了,其实就是匹配到了文件名。

/$ mkdir /tmp/glob_test && cd /tmp/glob_test
/tmp/glob_test$ echo [partition]
[partition]
/tmp/glob_test$ touch a
/tmp/glob_test$ echo [partition]
a
/tmp/glob_test$ touch o
/tmp/glob_test$ echo [partition]
a o

也就是说出问题的机器上,运行脚本的环境刚好存在一个名为 a 的文件,于是这行脚本的行为就改变了。

本意是写入 [partition] 实际上写入了a

解决也很简单,加上引号。

echo "[partition]" >> xxx.config

glob简介

解决了问题,再回头认识下这个特性。这个叫 glob ,是 bash 的一个特性,可以实现文件名的通配。

最原始可追溯到 UNIX V6,后来就变成了 shell 内建的特性。

当字符串包含了 '?' '*' '[' 的时候就会触发匹配,自动展开成匹配到的文件列表,这个比正则表达式要弱一些,但胜在简单实用。

大家可能经常用到类似于 ls *.c' 之类的功能,这就是 glob 生效的地方。

这里不再详细列出语法,请参考 man 7 glob 或网上诸多文章,例如阮一峰老师就分享过:命令行通配符教程

有一个要注意的地方就是,这个匹配如果失败,就会原样输出,这也是上文的例子在多数情况下能工作的原因。

写在最后

写脚本时该加引号还是得加上的,养成良好的习惯可以少写 bug

另外,虽然 shellcheck 并不能检测到这种情况,但对于提高脚本质量还是很有帮助的,之前也介绍过,可参考:shellcheck 帮助你写出更好的脚本

本文地址: https://www.cnblogs.com/zqb-all/p/12489524.html

公众号: https://sourl.cn/nYkaiK

,

诚信在线是哪里的赌场

诚信在线是哪里的赌场(现:阳光在线官网)现已开放诚信在线手机版、诚信在线电脑客户端下载。诚信在线娱乐游戏公平、公开、公正,用实力赢取信誉。

Allbet Gaming声明:该文看法仅代表作者自己,与阳光在线无关。转载请注明:济宁人才网:脚本写一行echo也能写出bug ? glob了解一下
发布评论

分享到:

网剧《棋魂》今日开播 胡先煦张超演绎另类棋幻青春
3 条回复
  1. 深度时空
    深度时空
    (2020-04-25 01:48:50) 1#

    sunbetSunbet www.eyaeya.com和EYAEYA网强强联合,打造一站式全民直营平台,用资本、技术、服务在同行中获胜。Sunbet和EYAEYA网提供数十种线上纸牌、zhenren、电子游戏,致力打造公平公开公正的信誉平台。刷文来了

  2. 欧博亚洲APP下载
    欧博亚洲APP下载
    (2020-10-28 00:01:56) 2#

    Allbet手机版下载欢迎进入Allbet手机版下载(www.aLLbetgame.us):www.aLLbetgame.us,欧博官网是欧博集团的官方网站。欧博官网开放Allbet注册、Allbe代理、Allbet电脑客户端、Allbet手机版下载等业务。同意大家

  3. 欧博亚洲APP下载
    欧博亚洲APP下载
    (2020-10-28 00:02:42) 3#

    Allbet手机版下载欢迎进入Allbet手机版下载(www.aLLbetgame.us):www.aLLbetgame.us,欧博官网是欧博集团的官方网站。欧博官网开放Allbet注册、Allbe代理、Allbet电脑客户端、Allbet手机版下载等业务。同意大家

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。