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

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

shell中的函数

1、#!/bin/bash
function inp(){
echo "The first parameter is $1"
echo "The second parameter is $2"
echo "The third parameter is $3"
echo "The number of parameter is $#"
echo "The script's name is $0"
}
#定义一个函数
inp a b c asd sdg

运行结果:
The first parameter is a
The second parameter is b
The third parameter is c
The number of parameter is 5
The script's name is f1.sh

2、#!/bin/bash
function inp(){
echo "The first parameter is $1"
echo "The second parameter is $2"
echo "The third parameter is $3"
echo "The number of parameter is $#"
echo "The script's name is $0"
}
inp $1 $2 $3

运行结果:
[root@centos7 shell]# sh f1.sh a b c d
The first parameter is a
The second parameter is b
The third parameter is c
The number of parameter is 3
The script's name is f1.sh

3、sum() {
s=$[$1+$2]
echo "$s"
}
sum $1 $2

运行结果:
[root@centos7 shell]# sh f1.sh 2 4

6、#!/bin/sh
ip(){
ifconfig |grep -A1 "$1: " |tail -1|awk '{print $2}'

}

read -p 'please network name: ' n
myip=ip $n
echo "input ip:"$myip

运行结果:
[root@centos7 shell]# sh ip.sh 
please network name: ens37
input ip:192.168.136.128

数组

所谓数组,就是相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,在Shell中,用括号来表示数组,数组元素用“空格”符号分割开。

1、定义数组
a=(1,2,3,4,a)
2、查看
[root@centos7 shell]# echo ${a[*]}
1,2,3,4,a

数组的分片
[root@centos7 shell]# a=(seq 1 10)

[root@centos7 shell]# echo ${a[*]}
1 2 3 4 5 6 7 8 9 10

3、从第一个元素开始截取第三个

1 2 3

4、倒数第三个元素开始截取3个

8 9 10

5、更改元素
[root@centos7 shell]# a[1]=90
You have new mail in /var/spool/mail/root
[root@centos7 shell]# echo ${a[*]}
1 90 3 4 5 6 7 8 9 10

6、新增元素
[root@centos7 shell]# a[11]=11
[root@centos7 shell]# echo ${a[*]}
1 90 3 4 5 6 7 8 9 10 11

告警系统分析

需求:使用shell定制各种个性化告警工具,但是需要统一化管理、规范化管理。
思路:指定一个脚本包,包含主程序、子程序、配置文件、邮件引擎、输出日志等等。
主程序:作为整个程序的入口;
配置文件:是一个控制中心,它用来开关各个子程序,指定各个相关联的日志文件;
子程序:这才是真正的监控脚本,用来监控各个指标;
邮件引擎:是由一个Python程序来实现,它可以定义发邮件的服务器、发邮件人以及发邮件密码;
输出日志:整个监控系统要有日志输出。

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

程序架构:
shell中的函数、数组、告警系统分析

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










本文转自 iekegz 51CTO博客,原文链接:http://blog.51cto.com/jacksoner/2045919,如需转载请自行联系原作者
相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
目录
相关文章
|
2月前
|
机器学习/深度学习 运维 数据挖掘
运维告警不是“玄学”:聊聊怎么用机器学习优化事件关联分析
运维告警不是“玄学”:聊聊怎么用机器学习优化事件关联分析
173 3
|
存储 Shell
Shell 数组
【10月更文挑战第16天】
215 3
|
8月前
|
运维 监控 前端开发
Zabbix告警分析新革命:DeepSeek四大创新场景助力智能运维
面对日益复杂的IT环境,高效分析监控数据并快速响应成为运维的关键挑战。本文深入探讨了DeepSeek与Zabbix结合的创新应用,包括一键式智能告警分析、Zabbix文档知识库助手及钉钉告警增强功能。通过部署指南和实用脚本,展示了如何提升故障排查效率,为运维工程师提供高效解决方案。
830 5
|
9月前
|
人工智能 运维 监控
Zabbix告警分析新纪元:本地DeepSeek大模型实现智能化告警分析
本文由Zabbix中国峰会演讲嘉宾张世宏撰写,介绍如何通过集成Zabbix监控系统与深度求索(DeepSeek)AI助手,构建智能化告警处理方案。该方案利用Webhook机制传递告警信息,借助DeepSeek的智能分析能力,帮助运维团队快速识别问题根源并提供解决方案。文章详细描述了技术架构、环境搭建、Webhook配置及实际案例,展示了AI在运维领域的应用前景和优势。
1369 0
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
250 6
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
Shell PHP 索引
Shell 数组
10月更文挑战第2天
114 1
|
Shell KVM 虚拟化
Shell 数组编程
【8月更文挑战第22天】 Shell 数组编程
171 10
|
Shell
5.Electron之shell(使用系统默认浏览器打开网页)
5.Electron之shell(使用系统默认浏览器打开网页)
475 1
|
应用服务中间件 Shell nginx
shell分析nginx日志的一些指令
shell分析nginx日志的一些指令
166 0
下一篇
oss云网关配置