Shell脚本 变量命名及引用规范
1 全局变量定义 也叫环境变量 全部大写 多个单词用_连接
最后采用export连接
2 局部变量 普通变量 第二个单词首字母大写 驼峰命名法
local 只在本函数中生效
3适用于:全局变量 局部变量 函数变量 数组变更等
引用变量 若变量前后都有字符 ${APACHE_ERR}
若变量内容为字符串时,需要使用"${APACHE_ERR}"
若变量内容为整数时 最好直接使用 ${APACHE_ERR}
shell函数的命名及函数定义规范
如果需要区分常规的字符串 函数名前面可以加function
Get为取值函数 Do为处理函数
模块的启动和停止脚本 start_模块名.sh stop_模块名.sh
监控脚本通常 *_mon.sh后缀
控制脚本通常 *_ctl.sh后缀
shell脚本的代码风格
1易变的信息 最好都定义为变量 或使用特殊位置的参数
2 把shell的通用变量以配置文件的形式单独存放 以功能.cfg
来命名 例如nginx.conf 并放入conf目录下
引用时 使用source conf/nginx.conf 的形式加载
3 将程序的功能分段 分模块 采用函数等来实现 并存放到单独的函数文件里 如果是
通用的公共函数可以存放于/etc/init.d/functions 下
调用时采用source文件全路径即可
4 把脚本中的功能和配置明确分开 主脚本只用于实现程序主干 加载配置及加载函数等功能实现应尽量封装在子函数中
5 缩进规范 在使用条件语句时 每进行一层循环时或是循环内部的操作时 就使用一个缩进
推荐 使用4格空格缩进
示例
if [ id oldboy_dir ]
then #4个空格缩进
cd olodboy_dir #4个空格缩进
if [ -f oldboy_file ]
then #4个空格缩进
echo "DoSth" #4个空格缩进
fi # if与fi上下对应
cd ...
fi #if 对应fi
shell脚本的变量及文件检查规范
脚本中要检查配置项是否为空 是否可执行等
尤其是对应一些重要的会影响下面脚本正常运行的配置项
必须进行是否为空等的检查
if [ -n "$APACHE_ERR" ] # 字符串不为零 就是真 not zero
if [ -z "$APACHE_ERR" ] # 字符串为零 就是真 zero
shell脚本的调试
常见的shell脚本错误案例
1 if缺少结尾关键字
#shell脚本解释器 一般不会对脚本错误进行精确的定位 而是试图在结束一个语句时进行统计错误
2 循环语句缺少关键字
3 成对的符号 落了单
4 中括号2端没空格
5 多出来的单引号 双引号
6 变量赋值 与调用时 英文单词不一致
shell 脚本调试技巧
1 windows下的脚本 dos2unix格式转换一下
cat -v while.sh 能看出^M
安装dos2unix: yum -y install dos2unix
2 使用echo命令调试 并紧接着exit退出
3 使用bash命令调试参数
sh [-nvx] scripts.sh
参数说明
-n 不会执行脚本 仅查询脚本语法是否有问题 并给出错误的提示
-v 在执行脚本时,先将脚本的内容输出到屏幕上 然后执行脚本 如果有错误
也会给出错误提示
-z 将执行的脚本内容及输出显示到屏幕上
4 使用set命令调试部分脚本内容
set [-nvx]
set -n 读命令但是不执行
set -x 显示所有命令及其参数
set -v 显示读取的所有行
set +x 关闭调试功能
set 命令的最大特点 与bash -x 相比 set -x 可以缩小调试的作用域
示例
# !/bin/bash
set -x #开启脚本调试
for a in `seq 9`
do
for b in `seq 9`
do
[ $a -ge $b ] && echo -en "$a x $b" = "$(expr $a \* $b) "
done
set +x #关闭脚本调试
echo " "
done
提示加了set -x执行脚本时 就不需要sh -x了
最关键的还是要语法熟练 养成良好的编码习惯 提供编程思想 提高开发效率