在編寫啟動指令碼時,涉及到讀取配置檔案,特地記錄下shell指令碼讀取啟動檔案的方式。主要提供兩種格式的讀取方式,方式一配置檔案採用“[]”進行分割槽,方式二配置檔案中需要有唯一的配置項名稱。
配置檔案格式如下:
# cat -n config.ini
1 #MYSQL配置項
2 [MYSQL]
3 DB_HOST=192.168.0.1
4 DB_PORT=3306
5 DB_USER=root
6 DB_PASSWD=mysql1234
7 DB_NAME=system_manager1
8
9 #MYSQL_1配置項
10 [MYSQL_1]
11 MYSQL_DB_HOST=192.168.0.2
12 MYSQL_DB_PORT=2200
13 MYSQL_DB_USER=root
14 MYSQL_DB_PASSWD=mysql123456
15 MYSQL_DB_NAME=bigdata1
16 MYSQL_INIT_SQL='set slave;stop backup;'
17
18 #REDIS配置項
19 [REDIS]
20 DB_HOST=192.168.0.1
21 DB_PORT=6379
22 DB_ID=4
23 DB_PASSWD=redis1234
方式一:先試使用grep獲取配置項的開始行、結束行。
# grep -n -E '^\[' config.ini |grep -A 1 "\[MYSQL\]"|awk -F ':' '{print $1}'|xargs 2 10 # grep -n -E '^\[' config.ini |grep -A 1 "\[REDIS\]"|awk -F ':' '{print $1}'|xargs 19
在使用sed根據開始行、結束行獲取實際配置
# sed -n "2,10 s/DB_HOST=//p" config.ini 192.168.0.1 # sed -n "19,$ s/DB_PORT=//p" config.ini 6379
方式二:使用正則匹配唯一的配置項名稱,並顯示實際配置
# sed -r -n 's/(^MYSQL_INIT_SQL=)(.*)$/\2/p' config.ini 'set slave;stop backup;' # sed -r -n 's/(^MYSQL_DB_HOST=)(.*)$/\2/p' config.ini 192.168.0.2
完整指令碼如下:
# cat config.sh #!/bin/bash set -e exit_script(){ exit 1 } if [ "$#" = 0 ]; then echo "引數錯誤,命令格式為: ./config.sh configfile" exit_script else configPath=$1 fi function get_line_num(){ local configKey=$1 grep -n -E '^\[' ${configPath} |grep -A 1 "\[${configKey}\]"|awk -F ':' '{print $1}'|xargs } function get_config(){ #local configPath=$1 local configKey=$1 local configName=$2 local line_num=$(get_line_num $configKey) local startLine=$(echo $line_num |awk '{print $1}') local endLine=$(echo $line_num|awk '{print $2}') if [ ${endLine} ];then sed -n "${startLine},${endLine} s/${configName}=//p" ${configPath} else sed -n "${startLine},$ s/${configName}=//p" ${configPath} fi } if [ -f $configPath ];then MYSQL_DB_HOST=$(get_config MYSQL DB_HOST) else echo ${configPath}"檔案不存在,請檢查配置檔案是否存在" exit_script fi MYSQL_DB_PASSWD=$(get_config MYSQL DB_PASSWD) MYSQL_DB_USER=$(get_config MYSQL DB_USER) REDIS_DB_HOST=$(get_config REDIS DB_HOST) REDIS_DB_PASSWD=$(get_config REDIS DB_PASSWD) MYSQL_DB_HOST=$(sed -r -n 's/(^MYSQL_DB_HOST=)(.*)$/\2/p' $configPath) MYSQL_DB_NAME=$(sed -r -n 's/(^MYSQL_DB_NAME=)(.*)$/\2/p' $configPath) INIT_SQL=$(sed -r -n 's/(^MYSQL_INIT_SQL=)(.*)$/\2/p' $configPath) echo "MYSQL_DB_HOST="${MYSQL_DB_HOST} echo "MYSQL_DB_PASSWD="${MYSQL_DB_PASSWD} echo "MYSQL_DB_USER="${MYSQL_DB_USER} echo "REDIS_DB_HOST="${REDIS_DB_HOST} echo "REDIS_DB_PASSWD="${REDIS_DB_PASSWD} echo "-----------------分割線-------------" echo "使用sed讀取配置:MYSQL_DB_HOST="${MYSQL_DB_HOST} echo "使用sed讀取配置:MYSQL_DB_NAME="${MYSQL_DB_NAME} echo "使用sed讀取配置:MYSQL_INIT_SQL="${INIT_SQL}
實際執行結果:
# ./config.sh config.i config.i檔案不存在,請檢查配置檔案是否存在 # ./config.sh config.ini MYSQL_DB_HOST=192.168.0.2 MYSQL_DB_PASSWD=mysql1234 MYSQL_DB_USER=root REDIS_DB_HOST=192.168.0.1 REDIS_DB_PASSWD=redis1234 -----------------分割線------------- 使用sed讀取配置:MYSQL_DB_HOST=192.168.0.2 使用sed讀取配置:MYSQL_DB_NAME=bigdata1 使用sed讀取配置:MYSQL_INIT_SQL='set slave;stop backup;'