shell中的函數
•函數就是把一段代碼整理到了一個小單元中,並給這個小單元起一個名字,當用到這段代碼時直接調用這個小單元的名字即可。
格式: function f_name() {
command
}
函數必須要放在最前面
示例1:打印參數,$1 表示第一個參數,$0表示文件名 $#表示參數的個數
#!/bin/bash
function inp(){ #定義函數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 a l k 3 bm
腳本運行結果
[root@yang shell]# sh hs1.sh
The first par is a
The second par is l
The third par is k
The scritp name is hs1.sh
The number of par is 5
示例2:定義加法的函數
#!/bin/bash
sum() {
s=$[$1+$2]
echo $s
}
sum 10 20
示例3:輸入網卡的名字,顯示網卡的IP地址
#!/bin/bash
ip()
{
ifconfig |grep -A1 "$1: " |awk '/inet/ {print $2}'
}
read -p "Please input the eth name: " eth
ip $eth
shell中的數組
•定義數組 a=(1 2 3 4 5); echo ${a[@]}
• echo ${a[2]} 讀取第三個元素,數組從0開始
• echo ${a[*]} 等同於 ${a[@]} 顯示整個數組
[root@yang shell]# a=(1 2 3 4 5)
[root@yang shell]# echo ${a[@]}
1 2 3 4 5
[root@yang shell]# echo ${a[*]}
1 2 3 4 5
[root@yang shell]# echo ${a[0]}
1
[root@yang shell]# echo ${a[2]}
3
• echo ${#a[@]} 獲取數組的元素個數
[root@yang shell]# echo ${#a[@]}
5
• 數組賦值與更改,如果下標不存在則會自動添加一個元素
[root@yang shell]# a[5]=ss
[root@yang shell]# echo ${a[@]}
1 2 3 4 5 ss
[root@yang shell]# a[5]=nn
[root@yang shell]# echo ${a[@]}
1 2 3 4 5 nn
• 數組的刪除,使用unset
[root@yang shell]# unset a[5]
[root@yang shell]# echo ${a[@]}
1 2 3 4 5
[root@yang shell]# unset a
[root@yang shell]# echo ${a[@]}
• 數組分片
echo ${a[@]:3:4} 從第一個元素開始,截取3個
echo ${a[@]:0-3:2} 從倒數第3個元素開始,截取2個
[root@yang shell]# echo ${a[@]}
1 2 3 4 5 6 7 8 9 10
[root@yang shell]# echo ${a[@]:3:4}
4 5 6 7
[root@yang shell]# echo ${a[@]:0-3:2}
8
```9
• 數組替換
echo ${a[@]/8/ss} 把8替換爲ss
[root@yang shell]# echo ${a[@]/8/ss}
1 2 3 4 5 6 7 ss 9 1
• a=(${a[@]/8/cc}) 也可以直接複製
[root@yangshell]# a=(${a[@]/8/cc})
[root@yang shell]# echo ${a[@]}
1 2 3 4 5 6 7 cc 9 10
-----
# 告警系統需求分析
•需求:使用shell定製各種個性化告警工具,但需要統一化管理、規範化管理。
• 思路:指定一個腳本包,包含主程序、子程序、配置文件、郵件引擎、輸出日誌等。
• 主程序:作爲整個腳本的入口,是整個系統的命脈。
• 配置文件:是一個控制中心,用它來開關各個子程序,指定各個相關聯的日誌文件。
• 子程序:這個纔是真正的監控腳本,用來監控各個指標。
• 郵件引擎:是由一個python程序來實現,它可以定義發郵件的服務器、發郵件人以及發件人密碼
• 輸出日誌:整個監控系統要有日誌輸出。
•要求:我們的機器角色多種多樣,但是所有機器上都要部署同樣的監控系統,也就說所有機器不管什麼角色,整個程序框架都是一致的,不同的地方在於根據不同的角色,定製不同的配置文件。
• 程序架構:
(主目錄 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下是日誌。