DAY9

本文深入探讨了Shell脚本中的函数与数组概念,包括函数的定义与使用、数组的创建、元素操作及高级功能如分片与替换。同时,文章还介绍了如何利用Shell脚本构建统一规范的告警系统,通过主程序、配置文件、子程序等组件实现个性化监控与邮件通知。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

shell中的函数
格式:

格式: function f_name() {

         command

}

函数必须要放在最前面

示例1(用来打印参数)
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

示例2(用于定义加法)

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

示例3(用于显示IP)
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

shell中的数组
shell中的数组1

定义数组 a=(1 2 3 4 5); echo ${a[@]}
echo ${#a[@]} 获取数组的元素个数
echo ${a[2]} 读取第三个元素,数组从0开始
echo ${a[*]} 等同于 ${a[@]} 显示整个数组
数组赋值
a[1]=100; echo ${a[@]}
a[5]=2; echo ${a[@]} 如果下标不存在则会自动添加一个元素
数组的删除
uset a; unset a[1]
shell中的数组2

数组分片
a=(seq 1 5)
echo ${a[@]:0:3} 从第一个元素开始,截取3个
echo ${a[@]:1:4} 从第二个元素开始,截取4个
echo ${a[@]:0-3:2} 从倒数第3个元素开始,截取2个
数组替换
echo a[@]/3/100a=({a[@]/3/100} a=(a[@]/3/100a=({a[@]/3/100})
数组,就是一串字符串或者一串数字,形成的一个变量

定义数组

在这里插入图片描述

打印数组
在这里插入图片描述

查看数组中某个元素的值,从0开始

在这里插入图片描述

查看数组中元素的个数
在这里插入图片描述

元素赋值(如果下标不存在则会自动添加一个元素)

在这里插入图片描述

删除数组中的元素

在这里插入图片描述

数组分片

从第四个元素开始,截取4个
在这里插入图片描述

从倒数第三个元素开始,截取2个(倒数第三个必须写成0-3,不能写成-3)
在这里插入图片描述

数组的替换
在这里插入图片描述

告警系统需求分析
需求:使用shell定制各种个性化告警工具,但需要统一化管理、规范化管理。
思路:指定一个脚本包,包含主程序、子程序、配置文件、邮件引擎、输出日志等。
主程序:作为整个脚本的入口,是整个系统的命脉。
配置文件:是一个控制中心,用它来开关各个子程序,指定各个相关联的日志文件。
子程序:这个才是真正的监控脚本,用来监控各个指标。
邮件引擎:是由一个python程序来实现,它可以定义发邮件的服务器、发邮件人以及发件人密码
输出日志:整个监控系统要有日志输出。
要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件。
程序架构:
在这里插入图片描述

bin下是主程序
conf下是配置文件
shares下是各个监控脚本
mail下是邮件引擎log下是日志。

告警系统主脚本
为方便需要,所有的shell脚本放到 /usr/local/sbin/ 目录下

切换到 /usr/local/sbin/ 目录下,创建告警系统脚本
在这里插入图片描述

#!/bin/bash
#Written by aming.
# 是否发送邮件的开关(1表示所有监控项目都发送邮件)
export send=1
# 过滤ip地址(此处为本机网卡名称)
export addr=`/sbin/ifconfig |grep -A1 "ens33: "|awk '/inet/ {print $2}'`
dir=`pwd`
# 只需要最后一级目录名
last_dir=`echo $dir|awk -F'/' '{print $NF}'`
# 下面的判断目的是,保证执行脚本的时候,我们在bin目录里,#不然监控脚本、邮件和日志很有可能找不到
if [ $last_dir == "bin" ] || [ $last_dir == "bin/" ]; then
    conf_file="../conf/mon.conf"
else
    echo "you shoud cd bin dir"
    exit
fi
exec 1>>../log/mon.log 2>>../log/err.log
#做时间标记,并记录当前时间系统负载
echo "`date +"%F %T"` load average"
/bin/bash ../shares/load.sh
#先检查配置文件中是否需要监控502
if grep -q 'to_mon_502=1' $conf_file; then
    export log=`grep 'logfile=' $conf_file |awk -F '=' '{print $2}' |sed 's/ //g'`
#找出配置文件中该监控项日志的目录
    /bin/bash  ../shares/502.sh
fi
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值