一、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  mtu 1500
        inet 192.168.242.128  netmask 255.255.255.0  broadcast 192.168.242.255
--
ens37: flags=4163  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程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码
输出日志:整个监控系统要有日志输出。
要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件。

程序架构
shell脚本基础(四)_第1张图片

bin下是主程序;
conf下是配置文件;
shares下是各个监控脚本;
mail下是邮件引擎;
log下是日志。