函数就是把一段代码整理到了一个小单元中,并给这个小单元起一个名字,当用到这段代码时直接调用这个小单元的名字便可。python
function f_name() { command }
函数必需要放在脚本最前面。linux
[root@zlinux-01 shell]# vim func01.sh #! /bin/bash function input() { echo $1 $2 $3 $0 $# } input 4 5 6 ## $0 脚本名称 ## $1-9脚本执行时的参数1到参数9 ## $? 脚本的返回值 ## $# 脚本执行时,输入的参数的个数 [root@zlinux-01 shell]# sh func01.sh 4 5 6 func01.sh 3
[root@zlinux-01 shell]# vim func02.sh #!/bin/bash function sum() { sum=$[$1+$2] echo $sum } sum 1 2 [root@zlinux-01 shell]# sh func02.sh 3
[root@zlinux-01 shell]# ifconfig | grep -A1 ens //查看网卡IP ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.242.128 netmask 255.255.255.0 broadcast 192.168.242.255 -- ens37: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.248.128 netmask 255.255.255.0 broadcast 192.168.248.255 [root@zlinux-01 shell]# vim func03.sh #! /bin/bash function checkip() { ## awk -F分隔符用得空格,也能够用另外一种写法 ## ifconfig |grep -A1 "$1: "|awk '/inet/ {print $2}' ifconfig | grep -A1 "$1:" | tail -1 | awk -F ' ' '{print $2}' } read -p "请输入网卡名称:" eth checkip $eth [root@zlinux-01 shell]# sh func03.sh 请输入网卡名称:ens33 192.168.242.128 [root@zlinux-01 shell]# sh func03.sh 请输入网卡名称:ens37 192.168.248.128
定义数组 a=(1 2 3 4 5); echo ${a[@]} echo ${#a[@]} 获取数组的元素个数 echo ${a[2]} 读取第三个元素,数组从0开始 echo ${a[*]} 等同于 ${a[@]} 显示整个数组
数组赋值shell
a[1]=100; echo ${a[@]} a[5]=2; echo ${a[@]} 若是下标不存在则会自动添加一个元素 数组的删除 unset a; unset a[1]
数组分片vim
a=(seq 1 5) echo ${a[@]:0:3} 从第一个元素开始,截取3个 echo ${a[@]:1:4} 从第二个元素开始,截取4个 echo ${a[@]:0-3:2} 从倒数第3个元素开始,截取2个 数组替换 echo ${a[@]/3/100} a=(${a[@]/3/100})
需求:使用shell定制各类个性化告警工具,但须要统一化管理、规范化管理。
思路:指定一个脚本包,包含主程序、子程序、配置文件、邮件引擎、输出日志等。
主程序:做为整个脚本的入口,是整个系统的命脉。
配置文件:是一个控制中心,用它来开关各个子程序,指定各个相关联的日志文件。
子程序:这个才是真正的监控脚本,用来监控各个指标。
邮件引擎:是由一个python程序来实现,它能够定义发邮件的服务器、发邮件人以及发件人密码
输出日志:整个监控系统要有日志输出。
要求:咱们的机器角色多种多样,可是全部机器上都要部署一样的监控系统,也就说全部机器无论什么角色,整个程序框架都是一致的,不一样的地方在于根据不一样的角色,定制不一样的配置文件。数组
程序架构bash
bin下是主程序;
conf下是配置文件;
shares下是各个监控脚本;
mail下是邮件引擎;
log下是日志。服务器