標籤:shell中的函數 shell中的數組 警示系統需求分析
七十、shell中的函數、shell中的數組、警示系統需求分析
一、shell中的函數
函數就是把一段代碼整理到了一個小單元中,並給這個小單元起一個名字,當用到這段代碼時直接調用這個小單元的名字即可。函數就是一個子shell,一個程式碼片段。
shell中的函數必須要定義在指令碼的最上面。
格式: function f_name() {
command
}函數必須要放在最前面
f_name:函數名,最好不要和shell中的一些關鍵詞衝突,比如for。
command:具體命令
function這個單詞可以省略掉的。
樣本1
#!//bin/bash
function inp(){
echo "The first par is $1"
echo "The serond par is $2"
echo "The third par is $3"
echo "the scritp name is $0"
echo "the number of par is $#"
}
inp a b 2 3 abc //如何調用上面的函數,直接input,再加函數名,就等於是調用它了,好比shell中的一條命令
# sh fun1.sh
The first par is a
The second par is b
The third par is 2
the scritp name is fun1.sh
the number of par is 5
也可以將參數放到外面
# vim fun1.sh
#!//bin/bash
function inp(){
echo "The first par is $1"
echo "The second par is $2"
echo "The third par is $3"
echo "the scritp name is $0"
echo "the number of par is $#"
}
inp $1 $2 $3 //這裡的$1代表的是fun1.sh的第一個參數
# sh fun1.sh 1 後面只跟一個1
The first par is 1
The second par is 這兩項都為空白
The third par is
the scritp name is fun1.sh
the number of par is 1 參數的個數為1
樣本2
# vim fun2.sh
#!/bin/bash
sum() {
s=$[$1+$2]
echo $s
}
sum 1 2
# sh -x fun2.sh
+ sum 1 2 //就是$1+$2,$1=1,$2=2。
+ s=3
+ echo 3
3
樣本3
#!/bin/bash
ip(){
ifconfig |grep -A1 "$1: " |tail -1 |awk '{print $2}'
}
read -p "Please input the eth name: " eth
myip=`ip $eth`
echo "$eth address is $myip"
解析:
ifconfig |grep -A1 "$1: " |tail -1 |awk '{print $2}'|awk -F':' '{print $2}'
這裡指令碼裡要寫$1:,這個冒號,很關鍵,因為ifconfig出來網卡名字後都有個冒號。
# ifconfig |grep -A1 "ens33: " //命令列示範這三條命令:
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.93.130 netmask 255.255.255.0 broadcast 192.168.93.255
# ifconfig |grep -A1 "ens33: " |tail -1 //這裡tail -1也可以換成grep 'inet'
inet 192.168.93.130 netmask 255.255.255.0 broadcast 192.168.93.255
# ifconfig |grep -A1 "ens33: " |tail -1 |awk '{print $2}'
192.168.93.130
# sh -x fun3.sh 測試:
+ read -p 'Please input the eth name: ' eth
Please input the eth name: ens33
++ ip ens33
++ ifconfig
++ grep -A1 'ens33: '
++ tail -1
++ awk '{print $2}'
+ myip=192.168.93.130
+ echo 'ens33 address is 192.168.93.130'
ens33 address is 192.168.93.130
二、shell中的數組
一串字串或者一串數字,形成了一個變數,把這個變數叫數組。可以針對數組做操作,也可以取數組其中的某個值。
數組1:
定義數組 a=(1 2 3 4 5)
列印的格式: echo ${a[@]},裡面的@符號也可以改成*
echo ${#a[@]} 擷取數組的元素個數
echo ${a[2]} 讀取某個元素的值,從0開始:0,1,2,3,4,5;方括弧裡的數字表示它的下標(元素是第幾個位置)
echo ${a[*]} 等同於 ${a[@]} 顯示整個數組
數組賦值:
元素的賦值,更改、覆蓋,進行替換
a[3]=100
echo ${a[@]}
a[5]=2
echo ${a[@]} //如果下標不存在則會自動添加一個元素
數組的刪除
unset a 刪除整個數組
unset a[1] 刪除數組裡的元素
數組2:
數組分區
a=(`seq 1 10`) 數組賦值可以使用seq
echo ${a[@]:0:3} 從第0個元素開始,截取多少個
echo ${a[@]:1:4} 比如從第二個元素開始,截取4個
echo ${a[@]:0-3:2} 從倒數第3個元素(0-3)開始,截取2個
數組替換:
echo ${a[@]/3/99} //echo替換,將3替換成99
a=(${a[@]/3/99}) //直接賦值,要用小括弧括起來,很關鍵
三、警示系統需求分析
shell項目-警示系統
需求:使用shell定製各種個人化警示工具,但需要統一化管理、正常化管理。
思路:指定一個指令碼包,包含主程式、子程式、設定檔、郵件引擎、輸出日誌等。
主程式:作為整個指令碼的入口,是整個系統的命脈。執行警示系統時直接執行主程式,要寫一個調用這些函數的指令碼。
設定檔:是一個控制中心,用它來開關各個子程式,指定各個相關聯的記錄檔。
子程式:這個才是真正的監控指令碼,用來監控各個指標。不需要直接執行,會被主程式調用。while,for,監控系統負載的就放在子程式裡。
郵件引擎:是由一個python程式來實現,它可以定義發郵件的伺服器、發郵件人以及寄件者密碼,調用第三方的郵件,比如163。
輸出日誌:整個監控系統要有日誌輸出。
要求:我們的機器角色多種多樣,但是所有機器上都要部署同樣的監控系統,也就說所有機器不管什麼角色,整個程式架構都是一致的,不同的地方在於根據不同的角色,定製不同的設定檔。
程式架構:
bin下是主程式
conf下是設定檔
shares下是各個監控指令碼
mail下是郵件引擎
log下是日誌。
七十、shell中的函數、shell中的數組、警示系統需求分析