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下是日志。