运行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!‘
|
显然这样用是可以的。
3.那到底是哪里出了问题呢?
使用方式来讲,一般使用 sh XX.sh 或者 ./XX.sh ,尝试一下./ 执行,果然成功。那问题的结症找到,
但是交互和脚本之间的差距在于#!/bin/bash——指定环境变量。那具体是什么原因呢?
xiaobai @XXX :~$ ls -hl /bin | grep sh
|
原来是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没有提供)。具体影响在哪里还在研究中。