Shell
1 Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
我们先写一个简单的脚本,执行以后再解释各个变量的意义
# touch variable
# vi variable
脚本内容如下:
#!/bin/sh
echo "number:$#"
echo "scname:$0"
echo "first :$1"
echo "second:$2"
echo "argume:$@"
echo
"show parm list:$*"
echo "show process id:$$"
echo "show precomm stat: $?"
保存退出
赋予脚本执行权限
# chmod +x variable
执行脚本
# ./variable aa bb
number:2
scname:./variable
first:aa
second:bb
argume:aa bb
show
parm list:aa bb
show process id:24544
show
precomm stat:0
通过显示结果可以看到:
$# 是传给脚本的参数个数
$0 是脚本本身的名字
$1 是传递给该shell脚本的第一个参数
$2 是传递给该shell脚本的第二个参数
$@ 是传给脚本的所有参数的列表
$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个
$$ 是脚本运行的当前进程ID号
$? 是显示最后命令的退出状态,0表示没有错误,其他表示有错误
2 linux 下 `dirname $0`
【`】,学名叫“倒引号”, 如果被“倒引号”括起来,
表示里面需要执行的是命令。
比如 `dirname $0`, 就表示需要执行
dirname $0 这个命令
【“”】 , 被双引号括起来的内容, 里面 出现
$ (美元号: 表示取变量名) `(倒引号: 表示执行命令)
\(转义号: 表示转义), 其余的才表示字符串。
【’‘】, 被单引号括起来的内容, 里面所有的都表示串, 包括上面所说的
三个特殊字符。
在命令行状态下单纯执行 $ cd `dirname $0` 是毫无意义的。因为他返回当前路径的"."。
这个命令写在脚本文件里才有作用,他返回这个脚本文件放置的目录,并可以根据这个目录来定位所要运行程序的相对位置(绝对位置除外)。
$0:当前Shell程序的文件名
dirname $0,获取当前Shell程序的路径
cd `dirname $0`,进入当前Shell程序的目录
在/home/admin/test/下新建test.sh内容如下:
- cd `dirname $0`
- echo `pwd`
然后返回到/home/admin/执行
- sh test/test.sh
运行结果:
- /home/admin/test
这样就可以知道一些和脚本一起部署的文件的位置了,只要知道相对位置就可以根据这个目录来定位,而可以不用关心绝对位置。这样脚本的可移植性就提高了,扔到任何一台服务器,(如果是部署脚本)都可以执行。
3 shell脚本-路径处理$(cd `dirname $0`; pwd)
#!/bin/bash
#得到当前输入的参数
PARAMETER=${0}
echo ${PARAMETER}
#得到当前输入参数的父级路径
PARAMETER_PATH=`dirname $0`
echo ${PARAMETER_PATH}
#得到当前执行命令的路径
CURRENT_PATH=`pwd`
echo ${CURRENT_PATH}
#得到当前执行命令+参数的父级路径组合的脚本的绝对路径
ROOT_PATH=$(cd `dirname $0`; pwd)
echo ${ROOT_PATH}
#切换到脚本的路径下
cd ${ROOT_PATH}
#
#TODO
#
exit 0
例子:
数据路径:
/Users/peeno/work/project/script/untitled.sh
终端执行:
cd /Users/peeno/work/project
sh script/untitled.sh
输出结果:
script/untitled.sh
script
/Users/peeno/work/project
/Users/peeno/work/project/
script
linux shell脚本中 mode=${1:-sart}
$1代表第二个参数
m=${1:-start}表示
如果$1存在且不为空,m就是$1
如果$1不存在或为空,那么m就是start