shell腳本基礎(四)
阿新 • • 發佈:2018-04-20
shell一、shell中的函數
函數就是把一段代碼整理到了一個小單元中,並給這個小單元起一個名字,當用到這段代碼時直接調用這個小單元的名字即可。
1、函數格式
function f_name()
{
command
}
函數必須要放在腳本最前面。
2、shell函數實例
實例1:
[root@zlinux-01 shell]# vim func01.sh #! /bin/bash function input() { echo $1 $2 $3 $0 $# } input 4 5 6 ## $0 腳本名稱 ## $1-9腳本執行時的參數1到參數9 ## $? 腳本的返回值 ## $# 腳本執行時,輸入的參數的個數 [root@zlinux-01 shell]# sh func01.sh 4 5 6 func01.sh 3
實例2:
[root@zlinux-01 shell]# vim func02.sh
#!/bin/bash
function sum()
{
sum=$[$1+$2]
echo $sum
}
sum 1 2
[root@zlinux-01 shell]# sh func02.sh
3
實例3:檢查網卡IP
[root@zlinux-01 shell]# ifconfig | grep -A1 ens //查看網卡IP ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.242.128 netmask 255.255.255.0 broadcast 192.168.242.255 -- ens37: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.248.128 netmask 255.255.255.0 broadcast 192.168.248.255 [root@zlinux-01 shell]# vim func03.sh #! /bin/bash function checkip() { ## awk -F分隔符用得空格,也可以用另一種寫法 ## ifconfig |grep -A1 "$1: "|awk ‘/inet/ {print $2}‘ ifconfig | grep -A1 "$1:" | tail -1 | awk -F ‘ ‘ ‘{print $2}‘ } read -p "請輸入網卡名稱:" eth checkip $eth [root@zlinux-01 shell]# sh func03.sh 請輸入網卡名稱:ens33 192.168.242.128 [root@zlinux-01 shell]# sh func03.sh 請輸入網卡名稱:ens37 192.168.248.128
二、shell中的數組
定義數組 a=(1 2 3 4 5); echo ${a[@]}
echo ${#a[@]} 獲取數組的元素個數
echo ${a[2]} 讀取第三個元素,數組從0開始
echo ${a[*]} 等同於 ${a[@]} 顯示整個數組
數組賦值
a[1]=100; echo ${a[@]}
a[5]=2; echo ${a[@]} 如果下標不存在則會自動添加一個元素
數組的刪除
unset a; unset a[1]
數組分片
a=(seq 1 5) echo ${a[@]:0:3} 從第一個元素開始,截取3個 echo ${a[@]:1:4} 從第二個元素開始,截取4個 echo ${a[@]:0-3:2} 從倒數第3個元素開始,截取2個 數組替換 echo ${a[@]/3/100} a=(${a[@]/3/100})
三、告警系統需求分析
需求:使用shell定制各種個性化告警工具,但需要統一化管理、規範化管理。
思路:指定一個腳本包,包含主程序、子程序、配置文件、郵件引擎、輸出日誌等。
主程序:作為整個腳本的入口,是整個系統的命脈。
配置文件:是一個控制中心,用它來開關各個子程序,指定各個相關聯的日誌文件。
子程序:這個才是真正的監控腳本,用來監控各個指標。
郵件引擎:是由一個python程序來實現,它可以定義發郵件的服務器、發郵件人以及發件人密碼
輸出日誌:整個監控系統要有日誌輸出。
要求:我們的機器角色多種多樣,但是所有機器上都要部署同樣的監控系統,也就說所有機器不管什麽角色,整個程序框架都是一致的,不同的地方在於根據不同的角色,定制不同的配置文件。
程序架構
bin下是主程序;
conf下是配置文件;
shares下是各個監控腳本;
mail下是郵件引擎;
log下是日誌。
shell腳本基礎(四)