博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一个比较高级的脚本示例
阅读量:6118 次
发布时间:2019-06-21

本文共 1132 字,大约阅读时间需要 3 分钟。

此脚本是keepalive服务中用的监控脚本。

主要的高级部分体现在事先定义好的变量中。

[root@search63 ~]# cat /home/op/scripts/ha_keepalived_monitor.sh

#!/bin/sh

[global]

SCRIPT_PATH=$(cd "$(dirname "$0")"; pwd)

SCRIPT_NAME=$(basename "$0")
PARA_NUM="$#"
PROC_PID="$$"
LOG_DIR='/var/log/monitor'

vrrp_ip="172.16.136.117"

prog_flag="$MYSQL_HOME"
log_file="${LOG_DIR}/ha_keepalived.log"
record_time=$(date '+%Y-%m-%d %H:%M:%S')
chown_user='root'
chown_group='root'

Parse args use for

parse_arguments() {

for arg do
case "$arg" in
-H|--help)
usage
;;
-D|--debug)
set -x
;;
esac
shift
done
}

cd "${SCRIPT_PATH}"

parse_arguments $@
test ! -d "${LOG_DIR}" && mkdir -p "${LOG_DIR}" && chown "${chown_user}"."${chown_group}" "${LOG_DIR}"
prog_exists=$(ps -ef | grep "${prog_flag}" | grep -v grep | wc -l)
if [ "${prog_exists}" -eq 0 ];
then
vrrp_ip_exists=$(/sbin/ip a | grep "${vrrp_ip}" | wc -l)
if [ "${vrrp_ip_exists}" -ge 1 ];
then
/etc/init.d/keepalived stop
echo "[${record_time}] ERROR Detect mysql service does not exist, stop keepalived server!" >> "${log_file}"
chown "${chown_user}"."${chown_group}" "${log_file}"
fi
fi

exit 0

转载于:https://blog.51cto.com/jingfeng/2285412

你可能感兴趣的文章
公式推♂倒题
查看>>
vue实现点击展开,点击收起
查看>>
如何使frame能居中显示
查看>>
第k小数
查看>>
构建之法阅读笔记三
查看>>
写给对前途迷茫的朋友:五句话定会改变你的人生
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>