20.16/20.17 shell中的函數python
20.18 shell中的數組linux
20.19 告警系統需求分析shell
20.16/20.17 shell中的函數:數組
~1.bash
函數就是把一段代碼整理到了一個小單元中,並給這個小單元起一個名字,當用到這段代碼時直接調用這個小單元的名字便可。服務器
格式: function f_name() { 網絡
command }函數必需要放在最前面架構
~2.框架
示例1 (需求:這個函數用來打印你的參數的)分佈式
#!/bin/bash
input() { #能夠省略掉function,直接寫函數的名字
echo $1 $2 $# $0
}
input 1 a b #前面只要定義了這個函數,後面能夠直接調用它
實例:
#!/bin/bash
function inp () {
echo " $1 $2 $3 $0 $# " #咱們定義完了 $1 $2 $3下面就能夠直接引用他。$0表示的加班的名字。$#表示的有幾個參數
}
inp 1 a 2
[root@axinlinux-01 shell]# sh inp.sh
1 a 2 inp.sh 3 #這裏的1 a 2是上面的 $1 $2 $3這三個參數,你須要對應輸入的字符串(也能夠理解爲上面的$1 $2 $3爲你要輸入1 a 2的位置,$1表明了你輸入的1,$2表明了你輸入的a,$3表明了你輸入的2,$0表明腳本的名字,$#表明了輸入了幾個參數)
~~或者這樣寫,更直觀一些:
#!/bin/bash
function inp () {
echo " 這是第一個要輸入的參數 $1 "
echo " 這是第二個要輸入的參數 $2"
echo " 這是第三個要輸入的參數 $3"
echo " 這是腳本的名字 $0"
echo " 這是輸入了幾個參數 $#"
}
inp 1 a axin
[root@axinlinux-01 shell]# sh inp.sh
這是第一個要輸入的參數 1
這是第二個要輸入的參數 a
這是第三個要輸入的參數 axin
這是腳本的名字 inp.sh
這是輸入了幾個參數 3
~~也能夠引用inp的時候,用$1$2$3來:
#!/bin/bash
function inp () {
echo " 這是第一個要輸入的參數 $1 "
echo " 這是第二個要輸入的參數 $2"
echo " 這是第三個要輸入的參數 $3"
echo " 這是腳本的名字 $0"
echo " 這是輸入了幾個參數 $#"
}
inp $1 $2 $3 #此時的$1 $2 $3是你sh這個腳本的時候,後面加的相應的參數
[root@axinlinux-01 shell]# sh inp.sh 1 a 2 #這裏的 1 a 2纔是,你腳本里引用inp的時候輸入的 $1$2$3
這是第一個要輸入的參數 1
這是第二個要輸入的參數 a
這是第三個要輸入的參數 2
這是腳本的名字 inp.sh
這是輸入了幾個參數 3
~3.
示例2 (需求:輸入兩個數字,求和)
#!/bin/bash
sum() {
s=$[$1+$2] #這裏的$1與$2就是下面輸入的1和2,要引用的參數
echo $s
}
sum 1 2
~4.
示例3 (需求:查看一個網卡的IP。輸入網卡的名字,來顯示IP)
#!/bin/bash
ip() {
ifconfig |grep -A1 "$1 " |tail -1 |awk '{print $2}'|awk -F':' '{print $2}'
}
read -p "Please input the eth name: " e
myip=`ip $e`
echo "$e address is $myip"
不太完善,要加幾個判斷語句
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
20.18 shell中的數組:
所謂屬組爲一串字符串或者一串數字,他造成了一個變量。咱們把這個變量叫成屬組。
也會用到屬組的分片
~1.定義數組 a=(1 2 3 4 5); echo ${a[@]}
[root@axinlinux-02 shell]# a=(1 2 3 4 5)
[root@axinlinux-02 shell]# echo ${a[@]}
1 2 3 4 5
或者
[root@axinlinux-02 shell]# echo ${a[*]}
1 2 3 4 5
~2.echo ${#a[@]} 獲取數組的元素個數
[root@axinlinux-02 shell]# a=(1 2 3 4 5)
[root@axinlinux-02 shell]# echo ${#a[*]}
5
~3.echo ${a[2]} 讀取第三個元素,數組從0開始
[root@axinlinux-02 shell]# a=(1 2 3 4 5) #0表示第一個,1表示第二個
[root@axinlinux-02 shell]# echo ${a[0]}
1
~4.echo ${a[*]} 等同於 ${a[@]} 顯示整個數組
~5.數組賦值
a[1]=100; echo ${a[@]}
[root@axinlinux-02 shell]# a[1]=100 #修改第一個(也就是第二個)爲100
[root@axinlinux-02 shell]# echo ${a[*]}
1 100 3 4 5
a[5]=2; echo ${a[@]} 若是下標不存在則會自動添加一個元素
[root@axinlinux-02 shell]# a[5]=1000
[root@axinlinux-02 shell]# echo ${a[*]}
1 100 3 4 5 1000
~6.數組的刪除
unset a; unset a[1]
[root@axinlinux-02 shell]# unset a[5] #刪除第五個(也就是實際的第六個)
[root@axinlinux-02 shell]# echo ${a[*]}
1 2 3 4 5
[root@axinlinux-02 shell]# unset a #刪除整個屬組a
[root@axinlinux-02 shell]# echo ${a[*]}
#爲空
~~.數組分片(截取屬組裏的一段)
~1.a=(`seq 1 5`)
echo ${a[@]:0:3} 從第一個元素開始,截取3個 #0表示第一個
echo ${a[@]:1:4} 從第二個元素開始,截取4個
echo ${a[@]:0-3:2} 從倒數第3個元素開始,截取2個 #0-3表示從倒數第三個開始
數組替換(兩種)
echo ${a[@]/3/100} #把3替換成100。在echo裏直接替換
a=(${a[@]/3/100}) #把3替換成100。在a屬組裏直接賦值
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
20.19 告警系統需求分析:
zabbix屬於一種比較成熟的解決方案,但有時候zabbix也不能徹底知足咱們的需求。假如咱們須要搞一些很是冷門的監控,zabbix須要些自定義的腳本,還要去傳輸數據等等。那麼有時候服務器之間網絡有問題,沒有辦法從客戶端到服務端之間通訊,就沒辦法把客戶端數據上報到服務端上去。那就只能湊合用這個shell腳本監控一下
那咱們這個告警系統,其實是一個分佈式的。也就是須要在每一臺機器上放這些shell腳本。每一臺機器均可以獨立監控,不須要依賴其餘機器。
~1.需求:使用shell定製各類個性化告警工具,但須要統一化管理、規範化管理。
~2.思路:指定一個腳本包,包含主程序、子程序、配置文件、郵件引擎、輸出日誌等。
~3.主程序:做爲整個腳本的入口,是整個系統的命脈。
~4.配置文件:是一個控制中心,用它來開關各個子程序,指定各個相關聯的日誌文件。
~5.子程序:這個纔是真正的監控腳本,用來監控各個指標。
~6.郵件引擎:是由一個python程序來實現,它能夠定義發郵件的服務器、發郵件人以及發件人密碼
~7.輸出日誌:整個監控系統要有日誌輸出。
~8.要求:咱們的機器角色多種多樣,可是全部機器上都要部署一樣的監控系統,也就說全部機器無論什麼角色,整個程序框架都是一致的,
不一樣的地方在於根據不一樣的角色,定製不一樣的配置文件。
~9.程序架構:
(主目錄 mon)
____________________|_______________________________
| | | | |
bin conf shares mail log
| | | | |
[main.sh] [ mon.conf] [load.sh 502.sh] [mail.py mail.sh] [ mon.log err.log ]
bin下是主程序
conf下是配置文件
shares下是各個監控腳本
mail下是郵件引擎
log下是日誌。