设为首页 收藏本站
查看: 864|回复: 0

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

[复制链接]

尚未签到

发表于 2018-8-20 10:49:17 | 显示全部楼层 |阅读模式
  
  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>  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语法配置,及内容自动补便配置


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-554193-1-1.html 上篇帖子: shell脚本的条件测试与比较 下篇帖子: Linux Shell脚本生产环境下安全地删除文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表