shell中的函数、shell中的数组、告警系统需求分析

7月16日任务

20.16/20.17 shell中的函数
20.18 shell中的数组
20.19 告警系统需求分析

20.16/20.17 shell中的函数

函数就是一个子shell就是一个代码段,当定义好一个函数后就可以去引用它。

格式:
function f_name() {
command
} 函数必须要放在最前面

示例1:shell有$1 $2 $3 函数也是支持有$1 $2 $3

[root@jimmylinux- shell]# vi fun1.sh

#!/bin/bash
function inp(){
echo "The frist 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 $ $ $

脚本执行效果

[root@jimmylinux- shell]# sh fun1.sh
The frist par is
The second par is
The third par is
The scritp name is fun1.sh
The number of par is [root@jimmylinux- shell]# sh fun1.sh
The frist par is
The second par is
The third par is
The scritp name is fun1.sh
The number of par is
[root@jimmylinux- shell]#

示例2:定义一个加法函数,shell中定义的函数必须要放在第二行。

[root@jimmylinux- shell]# vi fun2.sh

#!/bin/bash
sum() {
s=$[$+$]
echo $s
} sum

脚本执行效果

[root@jimmylinux- shell]# sh fun2.sh

[root@jimmylinux- shell]# sh -x fun2.sh
+ sum
+ s=
+ echo

示例3:显示IP地址信息

[root@jimmylinux- shell]# vi fun3.sh

#!/bin/bash
ip() {
    ifconfig |grep -A1 "$1 " |tail - |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中的数组

所谓数组就是一串数字或者一串字符串形成的变量,可以对这个变量进行操作,比如可以取数组的其中某一个值进行分片处理。

数组格式 a=(1 2 3 4 5); echo ${a[@]}

[root@jimmylinux- ~]# a=(  )

[root@jimmylinux- ~]# echo ${a[@]}
  

查看其中某一个元素的值,有一个特殊性,方括号里面的数字表示它的下标,例如第1个就是第2个位置,计算机里面数组是从0开始的。

[root@jimmylinux- ~]# echo ${a[]}

[root@jimmylinux- ~]# echo ${a[]}

[root@jimmylinux- ~]# echo ${a[]}

获取数组的元素个数

[root@jimmylinux- ~]# echo ${#a[@]}  #号表示一个个数

数组赋值

[root@jimmylinux- ~]# a[]=b
[root@jimmylinux- ~]# echo ${a[*]}
b
[root@jimmylinux- ~]# a[]=bbb
[root@jimmylinux- ~]# echo ${a[*]}
bbb

如何删除元素和数组

[root@jimmylinux- ~]# unset a[]  表示删除一个元素
[root@jimmylinux- ~]# echo ${a[*]} [root@jimmylinux- ~]# unset a 表示删除整个数组
[root@jimmylinux- ~]# echo ${a[*]} [root@jimmylinux- ~]#

数组的分片

[root@jimmylinux- ~]# a=(`seq  `)
[root@jimmylinux- ~]# echo ${a[*]} [root@jimmylinux- ~]# echo ${a[@]::} 从第3个元素开始,截取4个 [root@jimmylinux- ~]# echo ${a[@]:-:} 从倒数第3个元素开始,截取2个

数组的替换,左边是要替换的值,右边是被替换的值。

[root@jimmylinux- ~]# echo ${a[@]//}

[root@jimmylinux- ~]# a=(${a[@]//})  也可以把a赋值,结果是一样的。
[root@jimmylinux- ~]# echo ${a[@]}

20.19 告警系统需求分析

作为一个shell项目,告警系统是zabbix外的一个定制化需求

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

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

主程序:  整个脚本的入口,整个系统的命脉
配置文件:控制中心,来开关各个子程序,指定各个相关联的日志文件
子程序: 才是真正的监控脚本,监控各项指标
邮件引擎:由python程序实现,定义发邮件的服务器,发件人,密码等。
日志文件:整个监控系统要有日志输出到日志文件里

要求:被监控的机器角色多种多样,所有机器上部署一样的监控系统,不管什么机器整个监控程序的框架是一致的,不同角色定制不同的配置文件

程序架构:

主目录mon: 包含子目录bin、conf、shares、mail、log
子目录bin: 主程序脚本 main.sh
子目录conf:配置文件 mon.conf
子目录shares:监控子脚本 load.sh .sh
子目录mail:邮件引擎文件 mail.py mail.sh
子目录log: 日志文件 mon.log err.log
上一篇:Logstash生产环境实践手册(含grok规则示例和ELKF应用场景)


下一篇:Shell 函数 & 数组