20.16-20.17 shell中的函数
格式: function f_name() { command } 函数必须要放在最前面
- 脚本实例1
#!/bin/bash function inp(){ echo $1 $2 $3 $0 $# } inp 1 a 2
- 脚本实例2
#!/bin/bash sum() { s=$[$1+$2] echo $s } sum 1 2
- 脚本实例3
#!/bin/bash ip() { ifconfig |grep -A1 "$1: "|awk '/inet/ {print $2}' } read -p "Please input the eth name: " eth ip $eth
20.18 shell中的数组
-
定义数组 a=(1 2 3 4 5); echo ${a[@]}
- echo ${#a[@]} 获取数组的元素个数
- echo ${a[2]} 读取第三个元素,数组从0开始
- echo ${a[*]} 等同于 ${a[@]} 显示整个数组
数组赋值
数组分片
- 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})
20.19 告警系统需求分析
- 需求:使用shell定制各种个性化告警工具,但需要统一化管理、规范化管理。
- 主程序:作为整个脚本的入口,是整个系统的命脉。
- 配置文件:是一个控制中心,用它来开关各个子程序,指定各个相关联的日志文件。
- 子程序:这个才是真正的监控脚本,用来监控各个指标。
- 邮件引擎:是由一个python程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码
- 输出日志:整个监控系统要有日志输出。
- 要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件。
程序架构