专栏首页QB杂货铺脚本写一行echo也能写出bug ? glob了解一下

脚本写一行echo也能写出bug ? glob了解一下

背景

最近处理一个 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 帮助你写出更好的脚本

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 在shell脚本中添加暂停,按任意键继续

    zqb_all
  • nor flash之频率限制

    支持一款nor flash时,出于性能考虑,一般会查看其nor支持的最高频率以及主控端spi控制器的最高频率,以选择一个合适的运行频率。

    zqb_all
  • shell命令行混合进制计算器smartbc

    查了下,有个东西叫 bc, 具体的使用就不赘述了,可以运行bc,然后进去计算,也可以echo传递过去,大概是像这样

    zqb_all
  • iOS开发之地图

    在iOS开发中,地图也是很多App都需要使用的功能。本文主要对iOS中的地图知识点进行介绍。需要说明的是地图看似很复杂,其实它仅仅是一个控件,就和UIButto...

    YungFan
  • 常见图片格式详解系列(二)----BMP

    BMP是windows的一种图片格式,其组织方式其实相对简单喽,一个简单表示bmp文件的头结构 (BITMAPFILEHEAER)+ 一个表示图片信息的结构(B...

    视界音你而不同
  • ASP.NET Core 对Controller进行单元测试

    单元测试对我们的代码质量非常重要。很多同学都会对业务逻辑或者工具方法写测试用例,但是往往忽略了对Controller层写单元测试。我所在的公司没见过一个对Con...

    kklldog
  • Open3d学习计划—高级篇 2(彩色点云配准)

    Open3D是一个开源库,支持快速开发和处理3D数据。Open3D在c++和Python中公开了一组精心选择的数据结构和算法。后端是高度优化的,并且是为并行化而...

    点云PCL博主
  • MVC几种找不到资源的问题解决办法

    在MVC中,controller中的Action和View中的.cshtml文件名称有一个对应的关系。 当不对应时,有以下几种情况发生: 一、找不到视图的错误 ...

    小端
  • MyBatis工作原理

    在学习 MyBatis 程序之前,需要了解一下 MyBatis 工作原理,以便于理解程序。MyBatis 的工作原理如下图

    Java架构师必看
  • [答疑]EA14版本怎么恢复Project Browser

    老师,我的EA项目浏览器不小心关了,以前有个view菜单现在怎么没有了,怎么恢复呢?

    用户6288414

扫码关注云+社区

领取腾讯云代金券

,,