Shell脚本的书写规范与优秀的开发习惯

简介:

<--目录-->
1)脚本模块名
2)代码框架
3)函数规范
4)脚本存放规范
5)补充规范19条
6)优秀的开发习惯

【脚本模块名】
1、常规Shell脚本使用统一后辍:.sh,例:wsyht.sh
2、模块的启动和停止脚本统一命名为start_{模块名}.sh和sop_{模块名}.sh
3、监控脚本可以*_mon.sh为后辍,控制脚本以*_ctl.sh为后辍
4、模块(及其脚本和二进制程序)命名应该代表其特性和功能,不要使用个人名字缩写等形式命名
5、模块中的脚本和二进制程序命名禁止和其它脚本和二进制程序重名

【代码框架】
1、脚本开头解释器声明为 #!/bin/bash,也可以为#!/bin/sh,尽量统一
2、配置文件及库函数脚本等的引用如,source conf/httpd.conf
3、主脚本过程只实现程序主干,功能实现尽量封装在子函中
4、对于能独立执行的脚本要有 usage 和 version 函数,可以输出脚本用法和版本信息

5、规范代码树如下:
[root@localhost ~]# tree
|-- bin
| `-- ipsecct
|-- conf
| `-- ipsec.cfg
`-- func
`-- functions

【函数规范】
1、函数定义时在函数名前加上function保留字,虽然/etc/init.d/functions中没有这样做
2、尽量一行一条语句,而不是使用":"将多个语句隔开,尽可能多的判断操作是否成功,并对其进行相应处理
3、对于重要的函数,需说明函数用途,参数,返回值,作者,版本

【脚本存放规范】
1、服务控制脚本统一放置在/service/scripts目录下;如果多个运维人员,可以放在以自已用户命名的二级目录下

      如/server/scrips/username;比如我开发的脚本可以放在/server/scripts/wsyht下

【补充规范19条】
1、必须要有基本的日志输出
2、要关注脚本的效率和系统消耗,综合、平衡的考虑
3、函数参数传递:在调用函数时,向函数传递的参数如果是以变量的方式进行传递

     必须使用双引号将变量引起,这是为了防止某个变量中以多个空格分隔的字段,导致函数误认为是多个参数
4、避免cat大文件。比如for id in `cat id_file`;do … ;done。而是采用readline形试读入文件
5、对上一个命令需要if [ $? ]判断返回值,对于异常分支,需有相应的处理策略;或打印warning日志,或提示后退出
6、sort超过1G数据文件时,必须用-T指定临时文件夹,推荐在使用到sort的时候就使用-T指定到自身的TMP目录
7、避免使用大的while/for循环,如果实在需要,请考虑用awk命令替代
8、对于一系列有严格依赖关系的命令,请使用&&来处理

      比如:make mydir && mv myfile mydir; 对于有前后次序的脚本,禁止采用后台运行 & 命令。(推荐)
9、脚本运行前后,注意清除过期数据(上次运行生成的数据),注意rm的风险,可考虑替代方法,如find
10、对于功能较为复杂的脚本,考虑使用一些函数对功能点进行封装。这样可以使脚本清晰易读。(推荐)
11、任何出错情况必须将出错信息打印到日志中;严重的错误必须以邮件或短信报警的形式发出。(必须)
12、对于逻辑比较复杂的脚本,可以使用 set -x 来打印命令执行情况,便于调式和排错(推荐)。
13、wget之前,注意先删除本地文件;(推荐)
14、拷贝比较大的文件,最好先将文件cp到一个临时文件夹,然后mv到目标文件夹,避免下游模块读取到不完整文件
15、mv,cp模块,注意要使用命令全路径,直接强制替换,如/bin/cp -ap wsyht /tmp
16、脚本中,要注意对单引号'' 双引号"" 的转义,不明确转义启义的,在自测的时候多加小心。(推荐)
17、例用ps axuw|grep 来获取信息时,注意ps打印的最大宽度。建议多打几个w,例如ps auxwww|grep … ;(推荐)
18、使用sort,uniq,join,comm等命令时,要注意两点:

1) 是否要求排序(例如uniq,join,comm要求输入文件是排好序的);
2) 如果排序,要求以什么方式排序(例如,comm要求输入文件是排好序的,而不是数值序);(推荐)

19、对于Java程序脚本要环境变量的,写脚本前最好通过export重新声明环境变量,以免在定时任务场合使用出问题

【优秀的开发习惯】
1、尽量少用中文注释:如果非要用,要根据自身的客户端对服务器进行字符集调整
      如:export LANG="zh_CN.GB18030"在脚本中,调整下了符集

2、尽量以.sh为扩展名
      例:script-name.sh

3、书写代码习惯:
      a.成对内容的一次写出来。如:
     {}、[]、''、``、""
      b.流程控制语然一次书写完,如:
      if语句格式一次完成:
      c: 书写[]时,添内容之前直接两端的空格留出来,例: [ content ]
      d.变量的字符串定义加双引号,等号前后不能有空格。WSYHT_FILE="test.txt"
      e.变量的引用加双引号,大括号,"{WSYHT_FILE}"
      f.特别注意,脚本中的单引号

4、调整vim语法配置,及内容自动补便配置




本文转自 2012hjtwyf 51CTO博客,原文链接:http://blog.51cto.com/hujiangtao/1930661,如需转载请自行联系原作者
相关文章
|
23天前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
1月前
|
关系型数据库 Shell 网络安全
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
2月前
|
Shell Linux
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
139 32
|
2月前
|
JavaScript Shell C#
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
163 2
|
5月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
149 2
6种方法打造出色的Shell脚本
|
5月前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
223 1
|
5月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
208 2
|
11月前
|
Shell 索引
shell脚本入门到实战(四)- 数组
shell脚本入门到实战(四)- 数组
|
11月前
|
Shell
shell脚本入门到实战(三) - 变量
shell脚本入门到实战(三) - 变量
113 0
|
11月前
|
Shell Linux 人机交互
shell脚本入门到实战(二)--shell输入和格式化输出
shell脚本入门到实战(二)--shell输入和格式化输出
574 0