2018-4-20 17周3次课 shell函数、数组、告警需求分析

20.16/20.17 shell中的函数


·函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段代码时直接调用这个小单元的名字即可。

格式: 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

也可以把参数写在脚本外

1.png

[

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

2.png

[root@localhost shell]# sh -x fun2.sh
+ sum 1 2
+ s=3
+ echo 3
3


可以像例1一样,外部调用参数

3.png

[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"

4.png

下面这样写也可以得出ip:

ifconfig | grep -A1 "$1: " | awk '/inet/ {print $2}'


·课后作业:

输入网卡名,判断是不是空,是不是系统中的网卡

5.png

思路:首先解决输入为空的问题,如果输入内容为空,就提示要输入内容并重新循环,

其次要是系统中存在的网卡,而网卡配置文件在/etc/sysconfig/network-scripts/下,并且都以ifcfg-为开头,那么久可以以此判断输入的网卡名为名称的"ifcfg-网卡名”文件是否存在,如果存在则允许下步操作,否则重新循环





20.18 shell中的数组


·定义数组 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




20.19 告警系统需求分析


·需求:使用shell定制各种个性化告警工具,但需要统一化管理、规范化管理。

·思路:指定一个脚本包,包含主程序、子程序、配置文件、邮件引擎、输出日志等。

·主程序:作为整个脚本的入口,是整个系统的命脉。

·配置文件:是一个控制中心,用它来开关各个子程序,指定各个相关联的日志文件。

·子程序:这个才是真正的监控脚本,用来监控各个指标。

·邮件引擎:是由一个python程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码

·输出日志:整个监控系统要有日志输出。


要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件。


程序架构:                       

6.png

bin下是主程序

conf下是配置文件

shares下是各个监控脚本

mail下是邮件引擎

log下是日志


猜你喜欢

转载自blog.51cto.com/11530642/2106186
今日推荐