Message Queue --kafka - shell script to monitor kafka cluster node abnormalities mail mail

shell script to monitor kafka cluster node abnormalities mail mail code is as follows:

1, the configuration file:

filePath=/data/soft/kafka/kafka_2.12-2.2.0
[email protected]
sendEmailTitle=测试邮件主题
sendEmailContent=测试邮件内容

2, Code:

Note: sh path different linux device may be different, the need to see through which sh sh absolute path modifications.

#!/bin/sh
#防止中文乱码
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"

#file_conf.txt文件路径
file_conf="/data/shell/check_kafka_conf.txt"

#判断文件是否存在
if [ -f "${file_conf}" ];then
	
	echo $(date +'%Y-%m-%d %H:%M:%S')" 配置信息文件存在"

	#获取等号前内容,作为map中的Key值
	dbArrOne=($(awk -F'[=]' '{print $1}' ${file_conf} ))
	
	#获取等号后内容,作为map中的value值
	dbArrTwo=($(awk -F'[=]' '{print $2}' ${file_conf}))

	#创建一个空map
	declare -A map=()
	
	#通过循环,将db_backups_conf配置文件中的信息存储在map中
	for((i=0;i<${#dbArrOne[@]};i++))
	do
		map[${dbArrOne[i]}]=${dbArrTwo[i]}
	done
	
	#获取收件人的邮件账号的字符串
	semdEmailTo=${map["semdEmailTo"]}
	
	#获取默认的字符串分隔符
	old_ifs="$IFS"
	
	#设置字符串分隔符为逗号
	IFS=","
	
	#将收件人的邮件账号value值的字符串进行分隔,获取一个数组
	semdEmailToArr=($semdEmailTo)

	#将字符串的分隔符重新设置为默认的分隔符
	IFS="$old_ifs"

	kafka=`ps -ef | grep ${map["filePath"]} | grep -v 'grep' | awk '{print $2}'`
	
	if [ ${kafka} -gt 0 ];
	then
		echo "kafka正常"
	else
		#遍历收件人的邮箱地址,逐个发送邮件
		for email in ${semdEmailToArr[@]};
		do
			echo ""${map["sendEmailContent"]} | mail -s ""${map["sendEmailTitle"]} ${email}
		done
	fi
	
	

else
	echo "文件不存在"
fi

3, configuration parameters:

参数意义如下:
filePath=软件kafka绝对路径
semdEmailTo=收件人邮箱,多个收件人邮箱用逗号隔开
sendEmailTitle=测试邮件主题(文本内容中一定不能包含=)
sendEmailContent=测试邮件内容(文本内容中一定不能包含=)

4. Caution:

使用注意事项:
1、默认的是.sh、.txt文件都要放在/data/shell脚本下,如果放置的路径变了,需要修改.sh中读取.txt配置文件的路径
2、对于不同的Linux环境下,要修改db_backups_conf.txt文件中的配置信息,比如filePath的路径等信息
3、备份异常发送邮件提醒采用的是mail,运行的linux上提前先安装好mail并配置到mail.rc发送邮件的信息才可以。

 

Published 131 original articles · won praise 23 · views 10000 +

Guess you like

Origin blog.csdn.net/LSY_CSDN_/article/details/103723227