运行shell脚本经常碰到这个坑,但是又不知道是怎么回事,总是怀疑bash版本是不是支持[[ 用法。

1.检查bash版本。

bash --vserion

GNU bash, version 4.3.11(1)-release (x86_64-pc-linux-gnu)

想来基本不是版本问题。

2.[[ 使用错误。

在交互模式下使用:

xiaobai @XXX :~$ [[  1  ]] && echo  'successful!'
successful!

显然这样用是可以的。

3.那到底是哪里出了问题呢?

使用方式来讲,一般使用 sh XX.sh 或者 ./XX.sh ,尝试一下./ 执行,果然成功。那问题的结症找到,

但是交互和脚本之间的差距在于#!/bin/bash——指定环境变量。那具体是什么原因呢?

xiaobai @XXX :~$ ls -hl /bin | grep sh     
-rwxr-xr-x  1  root root 998K Oct   8   2014  bash
-rwxr-xr-x  1  root root 119K Feb  19   2014  dash
lrwxrwxrwx  1  root root     4  Dec  30  00 : 59  rbash -> bash
lrwxrwxrwx  1  root root     4  Dec  30  00 : 59  sh -> dash
lrwxrwxrwx  1  root root     4  Dec  30  00 : 59  sh.distrib -> dash
lrwxrwxrwx  1  root root     7  Nov  15   2013  static -sh -> busybox

原来是ubuntu 的sh指向的dash、并不是环境变量指定的bash,所以说./ 是可以的。sh 方式执行不行,那么显而易见的是 bash XX.SH 也可以但是我们并不会经常用的。

4. 接下去的问题就是dash 和 bash 有什么区别?

网上查了一下,ubuntu在6.10版本以后把系统默认的shell 改成了dash ,来自官方:dash(the Debian Almquist shell)是一个比bash小很多但仍兼容POSIX标准的shell,它占用的磁盘空间更少,执行shell脚本比bash更快,依赖的库文件更少,当然,在功能上无法与bash相比。dash来自于NetBSD版本的Almquist Shell(ash)。Ubuntu中将默认shell改为dash的主要原因是效率。由于Ubuntu启动过程中需要启动大量的shell脚本,为了优化启动速度和资源使用情况,Ubuntu做了这样的改动。

5.将dash修改为bash的方法。

sudo dpkg-reconfigure dash

选择no ,check。

需要注意的是,这样修改将会影响到系统的启动速度,甚至会影响到一些 依赖于dash独有特性的脚本(这些特性bash没有提供)。具体影响在哪里还在研究中。