论 shell 脚本编码规范的重要性

本文探讨了shell脚本编码规范的重要性,包括选择bash作为解释器,添加脚本版本、注释和调试功能,变量命名和命名规范,函数的编写,引用模块或文件的注意事项,以及日志管理和配置文件的组织。强调了良好的脚本实践能提高代码可读性和维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


适用代码多如牛毛,规范代码万里挑一      -- xuaijun


目录

编写shell脚本的一些规范

解释器

添加脚本版本和注释功能

添加脚本调试

变量命名

命名规范

函数

引用模块或文件

脚本日志

配置文件

编写shell脚本的一些基本常用规范

1.shell 解释器

unix/Linux上常见的Shell脚本解释器有bash、sh、csh、ksh等,习惯上把它们称作一种Shell,也就是shell脚本解释器

shell脚本一般选择bash作为解释器,脚本开头应为

2

3

#!/bin/bash

#!/bin/sh

 

添加脚本版本和注释功能

在脚本的开头加注释,说明脚本作者、编写时间、脚本功能,最好可以加上脚本的版本号。shell中脚本注释用#,注释语句和#号之间有一个空格

1

2

3

4

5

6

#!/bin/bash

 

# version:1.0.0          脚本版本

# author:xuaijun         脚本作者

# time:20210528 13:48:00    脚本时间

# features:部署虚拟化      脚本功能

 

添加脚本调试

通过set命令添加脚本调试,如果报错,脚本直接退出,不继续执行,对于管道错误也可以直接退出

1

2

3

#!/bin/bash

set -e

set -o pipfail

 

变量命名

变量命名要统一规范,shell变量建议使用全部大写,如果是多个字符,可以采用下划线进行切割,如:FILES_NAME_PATH,变量的引用可以直接使用$,如果有下划线分区的变量,建议使用${FILES_NAME_PATH}

全局变量和局部变量

全局变量可以采用前面时候的定义方式,如果是函数中的局部变量,建议使用local进行变量声明。这个防止全局变量和局部变量混淆,局部变量可以采用小写,用来区分局部变量和全局变量。

1

2

3

4

function foo(){

    local name='xuaijun,佛系程序员'

    echo ${name}

}

如果存在变量合并的情况,比如目录和文件名合并,这样可以重新赋值成一个新的变量,这样方便以后调用。

 

命名规范

 

函数命名

函数命名一般单词的首字母大写,比如Cpuinfo,意思清晰。

  • 获取最大值或最小值时后缀使用MaxMin
  • 获取信息或者返回值的函数可以使用Get作为前缀
  • 判断函数可以使用Is作为前缀

 

脚本命名

脚本命名,根据脚本功能进行命名,后缀为.sh,如果在脚本运行过程中产生一些临时文件,建议采用PID为后缀,如果脚本运行完成,这个文件没有用途,则自动进行删除。

1

2

PID=$$

TMP_FILE="ip_list".${PID}

 

函数

  • 函数定义,建议添加function关键字
  • 函数中缩进可以使用4个空格(或者tab,要根据默认tab几个空格来定义是否使用)
  • 函数中使用判断或者循环语句,使用统一风格,不要有的换行,有的不换行
  • 多管道语句,建议可以进行拆分,增加可读性,可以将通用部分提取
  • 使用 && 或 || 可以简化判断语句,语义更加清晰

 

引用模块或文件

引用脚本或者模块文件时,添加注释,简要说明模块的主要功能和作用,使用.或者source

 

脚本日志

脚本中建议添加日志函数,这样方便脚本调试,脚本运行中各函数的输出和状态,日志文件中包括时间-日志级别-函数,日志创建log目录,有常规的log和错误log。

 

配置文件

在工程目录下创建conf目录,配置文件以.conf/.ini/.cfg为后缀,配置字段要风格统一,每个配置提供相关配置注释

其他

  • 脚本中路径变量,建议使用绝对路径,最后面不要使用/结尾,例如:LOG_DIR="/var/log"
  • 如果脚本中有重要文件拷贝,建议使用md5进行一致性检查,尤其是远程拷贝
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值