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,如需转载请自行联系原作者
相关文章
|
2月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
114 1
|
1月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
67 2
6种方法打造出色的Shell脚本
|
1月前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
62 1
|
1月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
52 2
|
2月前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
59 6
|
1月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
36 0
|
2月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
83 12
|
2月前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
77 2
|
3月前
|
Shell
shell脚本变量 $name ${name}啥区别
shell脚本变量 $name ${name}啥区别