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

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

一、shell中的函数

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

shell中的函数必须要定义在脚本的最上面。

格式: function f_name() {          

           command       

         }函数必须要放在最前面

f_name:函数名,最好不要和shell中的一些关键词冲突,比如for。

command:具体命令

function这个单词可以省略掉的。

示例1

#!//bin/bash

function inp(){

  echo "The first par is $1"

  echo "The serond par is $2"

  echo "The third par is $3"

  echo "the scritp name is $0"

  echo "the number of par is $#"

}


inp a b 2 3 abc   //如何调用上面的函数,直接input,再加函数名,就等于是调用它了,好比shell中的一条命令

# sh fun1.sh

The first par is a

The second par is b

The third par is 2

the scritp name is fun1.sh

the number of par is 5


也可以将参数放到外面

# vim fun1.sh

#!//bin/bash

function inp(){

  echo "The first 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 $1 $2 $3           //这里的$1代表的是fun1.sh的第一个参数

# sh fun1.sh 1     后面只跟一个1

The first par is 1

The second par is        这两项都为空

The third par is

the scritp name is fun1.sh

the number of par is 1        参数的个数为1


示例2

# vim fun2.sh

#!/bin/bash

sum() {

    s=$[$1+$2]

    echo $s

}

sum 1 2

# sh -x fun2.sh

+ sum 1 2            //就是$1+$2,$1=1,$2=2。

+ s=3

+ echo 3

3


示例3

#!/bin/bash

ip(){

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

}

read -p "Please input the eth name: " eth

myip=`ip $eth`

echo "$eth address is $myip"

解析:

ifconfig |grep -A1 "$1: " |tail -1 |awk '{print $2}'|awk -F':' '{print $2}'

这里脚本里要写$1:,这个冒号,很关键,因为ifconfig出来网卡名字后都有个冒号。

#  ifconfig |grep -A1 "ens33: "       //命令行示范这三条命令:

ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500

inet 192.168.93.130  netmask 255.255.255.0  broadcast 192.168.93.255

#  ifconfig |grep -A1 "ens33: " |tail -1      //这里tail -1也可以换成grep 'inet'

inet 192.168.93.130  netmask 255.255.255.0  broadcast 192.168.93.255

#  ifconfig |grep -A1 "ens33: " |tail -1 |awk '{print $2}'

192.168.93.130

# sh -x fun3.sh       测试:

+ read -p 'Please input the eth name: ' eth

Please input the eth name: ens33

++ ip ens33

++ ifconfig

++ grep -A1 'ens33: '

++ tail -1

++ awk '{print $2}'

+ myip=192.168.93.130

+ echo 'ens33 address is 192.168.93.130'

ens33 address is 192.168.93.130


二、shell中的数组

一串字符串或者一串数字,形成了一个变量,把这个变量叫数组。可以针对数组做操作,也可以取数组其中的某个值。

数组1:

定义数组 a=(1 2 3 4 5)

打印的格式: echo ${a[@]},里面的@符号也可以改成*

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

echo ${a[2]} 读取某个元素的值,从0开始:0,1,2,3,4,5;方括号里的数字表示它的下标(元素是第几个位置)

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


数组赋值:

元素的赋值,更改、覆盖,进行替换

a[3]=100

echo ${a[@]}

a[5]=2

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


数组的删除

unset a       删除整个数组

unset a[1]   删除数组里的元素


数组2:

数组分片

a=(`seq 1 10`)            数组赋值可以使用seq

echo ${a[@]:0:3}       从第0个元素开始,截取多少个

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

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


数组替换:

echo ${a[@]/3/99}       //echo替换,将3替换成99

a=(${a[@]/3/99})        //直接赋值,要用小括号括起来,很关键


三、告警系统需求分析

shell项目-告警系统

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

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

主程序:作为整个脚本的入口,是整个系统的命脉。执行告警系统时直接执行主程序,要写一个调用这些函数的脚本。

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

子程序:这个才是真正的监控脚本,用来监控各个指标。不需要直接执行,会被主程序调用。while,for,监控系统负载的就放在子程序里。

邮件引擎:是由一个python程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码,调用第三方的邮件,比如163。

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

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

程序架构:

1.png

bin下是主程序

conf下是配置文件

shares下是各个监控脚本

mail下是邮件引擎

log下是日志。


猜你喜欢

转载自blog.51cto.com/13576245/2128627
今日推荐