·函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段代码时直接调用这个小单元的名字即可。
格式: 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 3
echo ${a[@]:1:4} 从第二个元素开始,截取4个
[root@localhost shell]# echo ${a[*]:1:4} 2 3 4 5
echo ${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