企业Linux运维SHELL编写规范 原

1. 路径规定

为了方便维护人员维护,需要规定两个正式脚本的发布路径和维护人员的测试路径,不要将脚本放到规定路径以外,例如:

1.1 维护人员的测试路径:

/opt/tmn/user

该路径用于维护人员编写脚本是的测试路径,不要将正式使用的定时任务脚本放到该路径 在该路径下创建每个维护人员各自姓名拼音的文件夹:

/opt/tmn/user/zhang3
/opt/tmn/user/li4

1.2 正式脚本的发布路径:

/opt/tmn/wlzy

只用于放置正式发布的脚本路径,不要放置个人的测试脚本

1.3 定时任务明细存放路径:

/opt/tmn/crontab

每次修改定时任务之前将现有的定时任务备份至该目录

crontab -l > /opt/tmn/crontab/crontab.`date "+%Y%m%d%H%M"`

2. 编写一个脚本

每套脚本之间路径不要有交叉,将所有用到的脚本全部放在定义目录下 代码尽量简洁,不要啰嗦,注释得当 例如:编写一个给外系统传输网管传送接口数据的脚本

2.1 脚本名称定义

有意义,英文名,一目能看出大体功能,一般采用专业+功能定义 通常一个功能一个路径,不要将不同功能的脚本放到一个路径 本例是传输专业,给外系统提供接口数据,直真公司缩写zznode,故名字定义为trans_to_zznode,创建路径

/opt/tmn/wlzy/trans_to_zznode

2.2 脚本目录规范

/opt/tmn/wlzy/trans_to_zznode/bin    #执行程序路径
/opt/tmn/wlzy/trans_to_zznode/sql    #SQL文件路径
/opt/tmn/wlzy/trans_to_zznode/log    #日志文件路径
/opt/tmn/wlzy/trans_to_zznode/doc    #需求文档路径(该路径可以放置当时确定的需求文档、邮件等,以便后期查看)
/opt/tmn/wlzy/trans_to_zznode/data   #数据文件路径
/opt/tmn/wlzy/trans_to_zznode/cfg    #配置文件路径(注意,为了脚本的易读性,尽量减少配置文件的使用,不建议将数据库用户信息等放到配置文件中读取)

2.3 执行文件编写

每套脚本中用到的shell脚本尽量不要太多,通常每个shell脚本内容100行左右,主脚本名称要以main打头 文件中不要使用tab制表符,要采用4个空格代替 例如:vi main_trans_to_zznode.sh

#!/bin/bash
####################################################################################
##                         给传输网管传送接口数据
##
## 编写:张三
## 日期:2016/10/26 10:02:26 某市
## 功能:给传输网管传送接口数据,网管中心张工提出需求,
##      需要给直真传送xxx、xxx等资源,定时任务,每天x点执行
##
####################################################################################

#设置路径及环境变量
HOME_DIR=/opt/tmn/wlzy/trans_to_zznode                      #工作路径
BIN_DIR=${HOME_DIR}/bin                                     #执行程序路径
SQL_DIR=${HOME_DIR}/sql                                     #SQL文件路径
DATA_DIR=${HOME_DIR}/data                                   #文件路径
LOG_DIR=${HOME_DIR}/log                                     #日志路径
LOG_FILE=${LOG_DIR}/trans_to_zznode.log.`date "+%Y%m%d"`    #日志文件名称

#系统环境变量
. /etc/profile

#Oracle环境变量
ORACLE_HOME=/opt/oracle/product/11.2.0/db
PATH=$ORACLE_HOME/bin:$JAVA_HOME/bin:$PATH
LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
NLS_DATE_FORMAT="YYYY-MM-DD HH24:MI:SS"
NLS_TIMESTAMP_FORMAT="YYYY-MM-DD HH24:MI:SS"
export ORACLE_HOME NLS_LANG PATH NLS_DATE_FORMAT NLS_TIMESTAMP_FORMAT
dbuser_id="user1"
dbpass_word="123456"
dbserver_id="db1"

#FTP服务器相关信息
FTPADDR="192.168.14.1"
FTPPORT="21"
FTPUSER="ftpuser"
FTPPWD="123456"

echo "BEGINNING OF $0 ("`date`")" >>$LOG_FILE 2>&1

#1.生成接口数据
sqlplus -s ${dbuser_id}/${dbpass_word}@${dbserver_id}<${SQL_DIR}/toRoadNetwork.sql >>${LOG_FILE} 2>&1

#2.将文件FTP到本地服务器并关闭每次要求确认的模式
ftp -n<<!
open ${FTPADDR} ${FTPPORT}
user ${FTPUSER} ${FTPPWD}
binary
cd /
prompt
lcd ${DATA_DIR}
mput jizhongyouhuawf_*${current_date}.csv
close
bye
!

##删除日志
#find ${LOG_DIR} -name "*.log.*" -mtime +4 -exec rm {} \;
##删除数据文件
#find ${DATA_DIR} -name "*.csv" -mtime +4 -exec rm {} \;

echo "ENDING OF $0 ("`date`")" >>$LOG_FILE 2>&1

2.4 总结

该脚本一共分四块:1.功能说明、2.定义环境变量、3.执行功能(执行SQL、传输数据)、4.日志和文件清理

3. 定时备份

编写好的脚本,要加入定时备份,通常备份的文件存储到另外一台服务器上

4. 待续……

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏云计算

如何在Debian 9上设置MariaDB

MariaDB是MySQL的直接替代品。它致力于成为寻求强大,可扩展且可靠的SQL Server的数据库专业人员的合理选择。本指南将帮助初学者在Debian 9...

1.3K30
来自专栏数据和云

Oracle 12.2新特性掌上手册 - 第一卷 Availability

注:文章内容来自官方文档翻译。若需要了解更多,请查阅官方文档。 1、Multi-Instance Redo Apply (多实例redo应用) 在Oracle ...

39860
来自专栏软件工程师成长笔记

centOS7安装MySQL流程介绍

1、隐藏密码 如:MySQL 连接远程数据库(192.168.5.116),端口“3306”,用户名为“root”,密码“123456”(这是我乱写的地址哈)...

26220
来自专栏游戏杂谈

libcurl上传文件

libcurl参数很多,一不小心就容易遇到问题。曾经就遇到过一个很蛋疼的问题:libcurl断点下载>>

93210
来自专栏吴伟祥

分布式锁的几种实现方式~ 转

目前几乎很多大型网站及应用都是分布式部署的,分布式场景中的数据一致性问题一直是一个比较重要的话题。分布式的CAP理论告诉我们“任何一个分布式系统都无法同时满足一...

42210
来自专栏散尽浮华

Mysql优化系列(0)--总结性梳理

对于一个网站来说,在运行很长一段时间后,数据库瓶颈问题会越来越暴露出来。作为运维人员,对数据库做必要的优化十分重要! 下面总结以往查阅到的以及自己工作中的一些优...

22680
来自专栏iMySQL的专栏

MySQL FAQ 系列 : 如何安全地关闭 MySQL 实例

本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 MySQL 实例,对这个过程不甚清楚的同学可以参考下。

30700
来自专栏北京马哥教育

MySQL 数据库上线后根据 status 状态优化

马哥linux运维 | 最专业的linux培训机构 ---- 网上有很多的文章教怎么配置mysql服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文...

33160
来自专栏数据和云

高频错误:ORA-01555深入剖析

黄玮(Fuyuncat) 资深Oracle DBA,个人网站www.HelloDBA.com,致力于数据库底层技术的研究,其作品获得广大同行的高度评价. ORA...

33180
来自专栏云计算教程系列

如何在Ubuntu 16.04上安装和配置Zabbix以安全地监视远程服务器

Zabbix是用于web和应用程序的开源监控软件。它提供对从服务器,虚拟机和任何其他类型的网络设备收集的数千个指标的实时监控。这些指标可帮助确定IT基础架构的当...

21630

扫码关注云+社区

领取腾讯云代金券