70.shell的函数 数组 告警系统需求分析

只谈情不闲聊 提交于 2019-11-26 22:49:18

20.16/20.17 shell中的函数

20.18 shell中的数组

20.19 告警系统需求分析

 

 

 

 

 

 

 

20.16/20.17 shell中的函数:

 

 

 

 

 

~1.

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

格式: function f_name() { 

                    command             }函数必须要放在最前面

~2.

示例1 (需求:这个函数用来打印你的参数的)

#!/bin/bash

input() { #可以省略掉function,直接写函数的名字

    echo $1 $2 $# $0

}

 

input 1 a b #前面只要定义了这个函数,后面可以直接调用它

实例:

#!/bin/bash

function inp () {

echo " $1 $2 $3 $0 $# " #我们定义完了 $1 $2 $3下面就可以直接引用他。$0表示的加班的名字。$#表示的有几个参数

}

inp 1 a 2

[root@axinlinux-01 shell]# sh inp.sh

1 a 2 inp.sh 3 #这里的1 a 2是上面的 $1 $2 $3这三个参数,你需要对应输入的字符串(也可以理解为上面的$1 $2 $3为你要输入1 a 2的位置,$1代表了你输入的1,$2代表了你输入的a,$3代表了你输入的2,$0代表脚本的名字,$#代表了输入了几个参数)

~~或者这样写,更直观一些:

#!/bin/bash

function inp () {

echo " 这是第一个要输入的参数 $1 "

echo " 这是第二个要输入的参数 $2"

echo " 这是第三个要输入的参数 $3"

echo " 这是脚本的名字 $0"

echo " 这是输入了几个参数 $#"

}

inp 1 a axin

[root@axinlinux-01 shell]# sh inp.sh

这是第一个要输入的参数 1

这是第二个要输入的参数 a

这是第三个要输入的参数 axin

这是脚本的名字 inp.sh

这是输入了几个参数 3

~~也可以引用inp的时候,用$1$2$3来:

#!/bin/bash

function inp () {

echo " 这是第一个要输入的参数 $1 "

echo " 这是第二个要输入的参数 $2"

echo " 这是第三个要输入的参数 $3"

echo " 这是脚本的名字 $0"

echo " 这是输入了几个参数 $#"

}

inp $1 $2 $3 #此时的$1 $2 $3是你sh这个脚本的时候,后面加的相应的参数

[root@axinlinux-01 shell]# sh inp.sh 1 a 2 #这里的 1 a 2才是,你脚本里引用inp的时候输入的 $1$2$3

这是第一个要输入的参数 1

这是第二个要输入的参数 a

这是第三个要输入的参数 2

这是脚本的名字 inp.sh

这是输入了几个参数 3

 

~3.

示例2 (需求:输入两个数字,求和)

#!/bin/bash

sum() {

    s=$[$1+$2] #这里的$1与$2就是下面输入的1和2,要引用的参数

    echo $s

}

sum 1 2

~4.

示例3 (需求:查看一个网卡的IP。输入网卡的名字,来显示IP)

#!/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"

不太完善,要加几个判断语句

 

 

 

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

 

 

 

 

 

20.18 shell中的数组:

 

 

 

 

所谓属组为一串字符串或者一串数字,他形成了一个变量。我们把这个变量叫成属组。

也会用到属组的分片

~1.定义数组 a=(1 2 3 4 5); echo ${a[@]}

[root@axinlinux-02 shell]# a=(1 2 3 4 5)

[root@axinlinux-02 shell]# echo ${a[@]}

1 2 3 4 5

或者

[root@axinlinux-02 shell]# echo ${a[*]}

1 2 3 4 5

~2.echo ${#a[@]} 获取数组的元素个数

[root@axinlinux-02 shell]# a=(1 2 3 4 5)

[root@axinlinux-02 shell]# echo ${#a[*]}

5

~3.echo ${a[2]} 读取第三个元素,数组从0开始

[root@axinlinux-02 shell]# a=(1 2 3 4 5) #0表示第一个,1表示第二个

[root@axinlinux-02 shell]# echo ${a[0]}

1

~4.echo ${a[*]} 等同于 ${a[@]} 显示整个数组

~5.数组赋值

a[1]=100; echo ${a[@]}

[root@axinlinux-02 shell]# a[1]=100 #修改第一个(也就是第二个)为100

[root@axinlinux-02 shell]# echo ${a[*]}

1 100 3 4 5

a[5]=2; echo ${a[@]} 如果下标不存在则会自动添加一个元素

[root@axinlinux-02 shell]# a[5]=1000

[root@axinlinux-02 shell]# echo ${a[*]}

1 100 3 4 5 1000

~6.数组的删除

unset a; unset a[1]

[root@axinlinux-02 shell]# unset a[5] #删除第五个(也就是实际的第六个)

[root@axinlinux-02 shell]# echo ${a[*]}

1 2 3 4 5

[root@axinlinux-02 shell]# unset a #删除整个属组a

[root@axinlinux-02 shell]# echo ${a[*]}

#为空

~~.数组分片(截取属组里的一段)

~1.a=(`seq 1 5`)

echo ${a[@]:0:3} 从第一个元素开始,截取3个 #0表示第一个

echo ${a[@]:1:4} 从第二个元素开始,截取4个

echo ${a[@]:0-3:2} 从倒数第3个元素开始,截取2个 #0-3表示从倒数第三个开始

数组替换(两种)

echo ${a[@]/3/100} #把3替换成100。在echo里直接替换

a=(${a[@]/3/100}) #把3替换成100。在a属组里直接赋值

 

 

 

 

 

 

 

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

 

 

 

 

20.19 告警系统需求分析:

 

 

 

 

 

zabbix属于一种比较成熟的解决方案,但有时候zabbix也不能完全满足我们的需求。假如我们需要搞一些非常冷门的监控,zabbix需要些自定义的脚本,还要去传输数据等等。那么有时候服务器之间网络有问题,没有办法从客户端到服务端之间通信,就没办法把客户端数据上报到服务端上去。那就只能凑合用这个shell脚本监控一下

那我们这个告警系统,实际上是一个分布式的。也就是需要在每一台机器上放这些shell脚本。每一台机器都可以独立监控,不需要依赖其他机器。

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

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

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

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

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

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

~7.输出日志:整个监控系统要有日志输出。

~8.要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,

不同的地方在于根据不同的角色,定制不同的配置文件。

~9.程序架构:

                           (主目录 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下是日志。

 

 

 

 

 

 

 

 

 

 

 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!