shell编写总结

变量引用

  • $(VAR): 会将VAR当做一条命令来执行
  • '$VAR': 单引号中包含的变量, 不会被引用, 仍然输出$VAR
  • "$VAR": 双引号中包含的变量, 会被引用成$VAR的值输出
  • ``: 优先执行其中的命令, 用在字符串中时, 仅在""当中有效

有时需要在一个字符串变量中定义一个命令并预先包含一个变量名, 在使用时再转换成变量名, 此时可通过eval命令来达到目的.

CMD='eval echo $VALUE'
VALUE="Hello"

$CMD
# 执行echo "Hello", 输出"Hello"

特殊变量

  • $0: 获取当前执行脚本的文件名,包括路径
  • $n: 获取当前执行的shell脚本的第N个参数, n=1..9, 当n为0时表示脚本的文件名, 如果n大于9, 可用大括号括起来如${10}
  • $@: 这个程序的所有参数"$1" "$2" "$3"..., 这是将参数传递给其他程序的最佳方式, 因为会保留所有内嵌在每个参数里的空白
  • $*: 获取当前shell的所有参数,会将所有的命令行参数视为单个字符串
  • $?: 代表上一个命令执行是否成功的标志,如果执行成功则$? 为0, 否则不为0
  • $#: 获取当前shell命令行中参数的总个数
  • $_: 代表上一个命令的最后一个参数
  • $$: 代表所在命令的PID
  • $!: 代表最后执行的后台命令的PID

日志输出

shell脚本开发中, 输出的语句尽量不出现在标准输出, 除非是少数的步骤提示性语句, 如果是出错信息, 应存入到自己定义的出错日志中, 以便后期维护和调试, 其它不关心的信息直接输出到/dev/null中. 否则输出信息过多, 容易耗尽缓存, 造成脚本运行卡死, 难以调试定位.

  • date: 显示日期时间的命令, 可通过此命令来作为日志的前缀, 方便定位. 一般形式为 "[ date +%Y%m%d-%H%M%S` ]"
  • &[n]: 代表已经存在的文件描述符, &1代表输出, &2代表错误输出, &-代表关闭与它绑定的描述符, 如2>&1 错误输出绑定到标准输出, 2>&- 等价于2>/dev/null

条件判断

使用[ ]判断

注意事项

[ $HOME == $MALL ]

  • [ ]中每个组件都需要空格键来分格, 其中的变量最好都以双引号括起来, 常量最好都以单或双括起来
  • [ ]中==和'='结果都完全一样, 习惯上可尽量使用==
常用参数

数值比较

  • -ne: 比较两个参数是否不相等
  • -lt 参数1是否小于参数2
  • -le 参数1是否小于等于参数2
  • -gt 参数1是否大于参数2
  • -ge 参数1是否大于等于参数2
  • -n:判断变量是否有值

文件比较

  • -f 检查某文件是否存在
  • -d 检查目录是否存在
  • -x:判断是否存在并有可执行权限
  • -d: 文件为目录为真
  • -c: 文件为字符特殊文件为真
  • -b: 文件为块特殊文件为真
  • -s: 文件大小非0时为真
  • -t: 当文件描述符(默认为1)指定的设备为终端时为真

权限比较

  • -r: 用户可读为真
  • -w: 用户可写为真
  • -x: 用户可执行为真

相关推荐