今天聊一下shell开发时候的好方法,在开发shell中,经常需要定义一些配置文件,然后调用配置文件里面的内容,比如ftp账号,多个数据库信息,以及经常使用的固定目录等,可能都要分别进行配置,然后再shell中进行调用,实现起来简单,管理起来复杂,不利于后期运维,下面会介绍一种配置公共类的配置文件,配置简单,后期管理也简单,生产环境强烈推荐这类方法。
如下面代码单一配置文件,单纯的进行配置文件内容截取,仅仅适用于测试环境的开发和测试使用。
while read LIST_INFO do INFO=`echo $LIST_INFO` CODE=`echo $INFO | awk -F '|' '{ print $1 }'` DIR=`echo $INFO | awk -F '|' '{ print $2 }'` done < ${_V_CONFIG }interface_put.lst
而配置文件interface_put.lst的内容格式类似:
INTERFACE_NAME1|/data1/ INTERFACE_NAME2|/data2/ INTERFACE_NAME3|/data3/ INTERFACE_NAME4|/data4/
下面介绍推荐的公共类核心配置文件的使用方法,在核心配置文件,能够获取各类的配置信息,只要是定义好的信息,都能够在配置信息中找到,如环境路径,FTP账号密码,数据库信息等等。
如下,是我的核心配置文件(/data/config/config.ini)大概内容,定义了常用目录,数据库信息,FTP账号及密码等
[LOCALINFO] V_LOCAL_DIR=/data1/ V_REPORT_DIR=/data2/ [DBINFO] ORACLE_SCOTT=scott/123456@orcl ORACLE_MY=my/123456@mydb GP_CCDB=ccdb|127.0.0.1|5432|schema_name [FTPINFO] MYFTP=127.0.0.1|ftp|ftp_passwd
核心配置文件(/data/config/config.ini)配置完成之后,需要在使用的shell中调用
调用方法如下:
#!/bin/bash #初始化核心配置文件 CONFIGINFO=/data/config/config.ini # __readINI [配置文件路径+名称] [节点名] [键值] function __readINI() { local file=$1;local sec=$2;local key=$3 awk -F "[=]+" '/^\[[\t]*'$sec'[ \t]*\]/{a=1}a==1&&$1~/^[ \t]*'$key'[ \t]*/{gsub(/[\t]+/,"",$2);print $2;exit}' $file return $? }
引用核心配置文件(/data/config/config.ini)说明:
#获取数据根目录例子
_V_LOCAL_DIR=$( __readINI ${CONFIGINFO} LOCALINFO V_LOCAL_DIR )
注释:
_V_LOCAL_DIR在shell中代表获取数据目录的名称
CONFIGINFO代表引入的核心配置文件名称
LOCALINFO代表核心配置文件中的[节点名],也就是核心配置文件中的[LOCALINFO]
V_LOCAL_DIR代表核心配置文件中的[键值],也就是核心配置文件中的[LOCALINFO]下面定义的V_LOCAL_DIR
下面将完整shell写一下,当然只是一部分内容:
准备:
(1)核心配置文件(/data/config/config.ini)
(2)将要开发的shell
核心配置文件定义好之后,开始开发shell,内容如下
#!/bin/bash #初始化配置信息表 CONFIGINFO=/data/config/config.ini # __readINI [配置文件路径+名称] [节点名] [键值] function __readINI() { local file=$1;local sec=$2;local key=$3 awk -F "[=]+" '/^\[[\t]*'$sec'[ \t]*\]/{a=1}a==1&&$1~/^[ \t]*'$key'[ \t]*/{gsub(/[\t]+/,"",$2);print $2;exit}' $file return $? } #获取返回文件目录 _V_REPROT_DIR=$( __readINI ${CONFIGINFO} LOCALINFO V_REPORT_DIR ) #获取本地临时文件目录 _V_LOCAL_DIR=$( __readINI ${CONFIGINFO} LOCALINFO V_LOCAL_DIR ) #获取FTP账号 _FTP_INFO=$( __readINI ${CONFIGINFO} FTPINFO MYFTP ) V_FTP_IP=`echo ${_FTP_INFO}|awk -F '|' '{print $1}'` V_FTP_USER=`echo ${_FTP_INFO}|awk -F '|' '{print $2","$3}'` #获取oracle数据库scott用户连接信息 _D_LINK=$( __readINI ${CONFIGINFO} DBINFO ORACLE_SCOTT ) #获取GP数据库集群的信息 _GP_CCDB=$( __readINI ${CONFIGINFO} DBINFO GP_CCDB ) V_CCDB_NAME=`echo ${_GP_CCDB}|awk -F '|' '{print $1}'` V_CCDB_HOST=`echo ${_GP_CCDB}|awk -F '|' '{print $2}'` V_CCDB_PORT=`echo ${_GP_CCDB}|awk -F '|' '{print $3}'` V_CCDB_SCHEMA=`echo ${_GP_CCDB}|awk -F '|' '{print $4}'`
微信小程序已经上线,可通过下图扫一扫进行微信小程序浏览,也可以通过微信搜一搜输入“提灯宝箱”找到我的小程序。
评论