·函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段代码时直接调用这个小单元的名字即可。
格式: function f_name() {
command
}
函数必须要放在最前面
·示例1
#!/bin/bash
input() {                        ##定义f_name最好不要和shell里面的关键词冲突
    echo $1 $2 $# $0
}
input 1 a b$1 $2 第一个,第二个参数
$# 脚本名称
$0 参数数量
[root@localhost shell]# sh -x fun1.sh + input 1 a b + echo 1 a 3 fun1.sh 1 a 3 fun1.sh
也可以把参数写在脚本外

[
root@localhost shell]# sh -x fun1.sh 1 a d ##参数写在脚本外,名称后面,也行 + input 1 a d + echo 1 a 3 fun1.sh 1 a 3 fun1.sh
示例2
#!/bin/bash
sum() {
    s=$[$1+$2]
    echo $s
}
sum 1 2
[root@localhost shell]# sh -x fun2.sh + sum 1 2 + s=3 + echo 3 3
可以像例1一样,外部调用参数

[root@localhost shell]# sh -x fun2.sh 3 4 + sum 3 4 + s=7 + echo 7 7 [root@localhost shell]# sh -x fun2.sh 3421 4352 + sum 3421 4352 + s=7773 + echo 7773 7773
想要调用哪个函数,就在调用语句之前定义这个函数
示例3
#!/bin/bash
ip() {
    ifconfig |grep -A1 "$1" |tail -1 |awk '{print $2}'|awk -F':' '{print $2}'
}
read -p "Please input the eth name: " e
myip=`ip $e`
echo "$e address is $myip"
下面这样写也可以得出ip:
ifconfig | grep -A1 "$1: " | awk '/inet/ {print $2}'
·课后作业:
输入网卡名,判断是不是空,是不是系统中的网卡

思路:首先解决输入为空的问题,如果输入内容为空,就提示要输入内容并重新循环,
其次要是系统中存在的网卡,而网卡配置文件在/etc/sysconfig/network-scripts/下,并且都以ifcfg-为开头,那么久可以以此判断输入的网卡名为名称的"ifcfg-网卡名”文件是否存在,如果存在则允许下步操作,否则重新循环
·定义数组 a=(1 2 3 4 5); echo ${a[@]} 数组不一定要是数字
[root@localhost shell]# a=(1 2 3 4 5)
[root@localhost shell]# echo ${a[@]}
1 2 3 4 5
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5·echo ${#a[@]} 获取数组的元素个数
[root@localhost shell]# a=(1 2 3 4 5)
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5
[root@localhost shell]# echo ${#a[*]}
5·echo ${a[2]} 读取第三个元素,数组从0开始
[root@localhost shell]# echo ${a[0]}
1
[root@localhost shell]# echo ${a[1]}
2
[root@localhost shell]# echo ${a[2]}
3·echo ${a[*]} 等同于 ${a[@]} 显示整个数组
[root@localhost shell]# echo ${a[@]}
1 2 3 4 5
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5·数组赋值
·添加元素
·a[5]=100; echo ${a[@]}
[root@localhost shell]# a[5]=100
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 100
[root@localhost shell]# a[5]=aaa
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 aaa·a[6]=bbb; echo ${a[@]} 如果下标不存在则会自动添加一个元素
[root@localhost shell]# a[6]=bbb
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 aaa bbb·数组的删除
·unset a; unset a[1]
[root@localhost shell]# unset a[5]            ##删除第6个值
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 bbb
[root@localhost shell]# unset a[5]            ##再次删第6个元素,没有变化,因此下标不会变化
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 bbb
[root@localhost shell]# unset a[6]            ##下标没变,还是删除的第7个元素
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5
[root@localhost shell]# unset a                ##清空数组
[root@localhost shell]# echo ${a[*]}·数组分片
a=(`seq 1 10`)
echo ${a[@]:0:3} 从第一个元素开始,截取3个
[root@localhost shell]# a=(`seq 1 10`)
[root@localhost shell]# echo ${a[*]}
1 2 3 4 5 6 7 8 9 10
[root@localhost shell]# echo ${a[*]:0:3}
1 2 3echo ${a[@]:1:4} 从第二个元素开始,截取4个
[root@localhost shell]# echo ${a[*]:1:4}
2 3 4 5echo ${a[@]:0-3:2} 从倒数第3个元素开始,截取2个
[root@localhost shell]# echo ${a[@]:0-3:2}
8 9·数组替换
echo ${a[@]/3/100} 替换的是值
a=(${a[@]/3/100})
[root@localhost shell]# echo ${a[*]/3/100}
1 2 100 4 5 6 7 8 9 10
[root@localhost shell]# a=(${a[*]/3/100})
[root@localhost shell]# echo ${a[*]}
1 2 100 4 5 6 7 8 9 10·需求:使用shell定制各种个性化告警工具,但需要统一化管理、规范化管理。
·思路:指定一个脚本包,包含主程序、子程序、配置文件、邮件引擎、输出日志等。
·主程序:作为整个脚本的入口,是整个系统的命脉。
·配置文件:是一个控制中心,用它来开关各个子程序,指定各个相关联的日志文件。
·子程序:这个才是真正的监控脚本,用来监控各个指标。
·邮件引擎:是由一个python程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码
·输出日志:整个监控系统要有日志输出。
要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件。
程序架构:

bin下是主程序
conf下是配置文件
shares下是各个监控脚本
mail下是邮件引擎
log下是日志
2018-4-20 17周3次课 shell函数、数组、告警需求分析
原文:http://blog.51cto.com/11530642/2106186