16-Linux全自动脚本编写监控Mysql,支持自动部署配置主主模式

开发目的:实际企业项目中集群服务器宕机后,Mysql主主默认不支持重启后自动配置.一旦出现突发状况,给企业项目带来极大的不利与损失.本文旨在使用Linux系统,通过编写Linux脚本实现全自动监控Mysql服务,服务器宕机后会立即重启Mysql服务并自动配置主主模式.使系统仍然正常运行,服务器宕机的影响降低最小化.

开发背景:这里假如有2台已经配置了主主模式的数据库node1和node2.ip地址如下:

mysql node1:
172.26.2.114
mysql node2:
172.26.2.115

开发步骤:

在172.26.2.114和172.26.2.115两台服务器分别编写监控Mysql服务的脚本startup.sh用以自动检测Mysql服务是否正常运行.

#!/bin/bash
#author by xiaokai 2019-10-08
while true
do
sleep 5
count=`ps -ef | grep mysql | grep -v "grep" | wc -l`
#echo $count
if [ 0 == $count ]; then
    #进程不存在
    time2=$(date "+%Y-%m-%d %H:%M:%S")
    #echo "mysql服务宕机,正在重新启动"
    echo 'mysql服务宕机,宕机时间为:'$time2>>error.log
    sleep 2
    service mysqld restart
    sleep 15
    sh setMysql.sh
    sleep 5    
    echo 'mysql重新启动成功!!!'
#else
    #rest进程存在,杀掉进程
    #echo "mysql服务运行正常...持续监控中"
fi
#time=$(date "+%Y-%m-%d %H:%M:%S")
#echo "本轮监测完毕,当前时间为:"$time
done

3.在172.26.2.114和172.26.2.115两台服务器分别编写同步Mysql主主模式配置的脚本setMysql.sh.

这里假定数据库node1和node2节点的连接账号和密码为xiaokai和123456

#!/bin/bash
#author by xiaokai 2019-07-29
#-*- coding:utf-8 -*-

#重启数据库
#echo 'restart mysql1 node...'
#docker restart mysql1
#echo 'restart mysql2 node...'
#docker restart mysql2

echo -e "\e[1;34m connect mysql node1... \n"
echo 'connect mysql node1...'
#数据库ip
HOSTNAME1="172.26.2.114"
#数据库端口
PORT1="3306"
#数据库用户名
USERNAME1="xiaokai"
#数据库密码
PASSWORD1="123456"
#数据库名
DBNAME1="mysql"
#查询语句
select_sql="show master status"
#*#执行查询*
result1=`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${select_sql}"`
node1_file_position=`echo ${result1} | awk '{print $1}'` #获取到的第一个值
node1_Postion=`echo ${result1} | awk '{print $2}'` #获取到的第二个值
node1_comtend=`echo ${result1} | awk '{print $n}'` #获取到的第N个值

echo 'node1_file_position:'$node1_file_position
echo 'node1_Postion:'$node1_Postion
echo 'node1_comtend:'$node1_comtend

echo '***************************'
echo 'connect mysql node2...'
#数据库ip
HOSTNAME2="172.26.2.115"
#数据库端口
PORT2="3306"
#数据库用户名
USERNAME2="xiaokai"
#数据库密码
PASSWORD2="123456"
#数据库名
DBNAME2="mysql"
#查询语句
select_sql="show master status"
#*#执行查询*
result2=`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${select_sql}"`

node2_file_position=`echo ${result2} | awk '{print $1}'` #获取到的第一个值
node2_Postion=`echo ${result2} | awk '{print $2}'` #获取到的第二个值
node2_comtend=`echo ${result2} | awk '{print $n}'` #获取到的第N个值

echo 'node2_file_position:'$node2_file_position
echo 'node2_Postion:'$node2_Postion
echo 'node2_comtend:'$node2_comtend

#创建同步帐号并授权
create_acount_sql="create user 'xiaokai'@'%' identified by '123456"
`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${create_acount_sql}"`
grant_acount_sql="grant all on *.* to 'xiaokai'@'%' identified by '123456'"
`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${grant_acount_sql}"`

`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${create_acount_sql}"`
`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${grant_acount_sql}"`

echo '同步帐号授权完毕'

#配置从节点写入
stop_slave_sql="stop slave"
`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${stop_slave_sql}"`
`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${stop_slave_sql}"`
#配置node1
change_master_node1="CHANGE MASTER TO MASTER_HOST='${HOSTNAME1}',MASTER_PORT=${PORT1},MASTER_USER='${USERNAME1}',MASTER_PASSWORD='${PASSWORD1}',MASTER_LOG_FILE='${node1_file_position}',MASTER_LOG_POS=${node1_Postion}"
change_master_node2="CHANGE MASTER TO MASTER_HOST='${HOSTNAME2}',MASTER_PORT=${PORT2},MASTER_USER='${USERNAME2}',MASTER_PASSWORD='${PASSWORD2}',MASTER_LOG_FILE='${node2_file_position}',MASTER_LOG_POS=${node2_Postion}"

echo ${change_master_node1}
echo ${change_master_node2}

echo '==============================================='
start_slave_sql="start slave"

`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${change_master_node1}"`
sleep 1s
`mysql -h${HOSTNAME2}  -P${PORT2}  -u${USERNAME2} -p${PASSWORD2} ${DBNAME2} -Bse "${start_slave_sql}"`
sleep 1s
`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${change_master_node2}"`
sleep 1s
`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${start_slave_sql}"`

#回调slave状态
show_slave_sql="show slave status"
slave1_status=`mysql -h${HOSTNAME1}  -P${PORT1}  -u${USERNAME1} -p${PASSWORD1} ${DBNAME1} -Bse "${show_slave_sql}"`
slave_node1_status=`echo ${slave1_status} | awk '{print $n}'`
echo 'node1:'${slave_node1_status}
echo '执行完毕'

echo -e '\e[0m'
#查询语句
#select_sql2='select now()'
#dateResult=`mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -Bse "${select_sql2}"` 
#time2=`echo ${dateResult}|awk '{print $n}'`
#echo 'time:'$time2

4.分别在两台服务器启动startup.sh和setMysql.sh脚本(两个脚本放在同一目录下),以后台命令启动即可以实现后台监控.

nohup startup.sh &
5.因服务器宕机后脚本会失效,所以还要额外在服务器添加crontab任务.

输入命令crontab -e打开任务配置界面

@reboot(sleep 10; nohup \location\startup.sh )
这样配置后服务器宕机后,重启后也会自动后台加载启动脚本实现全自动监控配置Mysql服务啦.

最后总结:因Mysql主主官方默认不支持重启后自动配置主主模式,使用Linux脚本可以极大简化开发时间成本,实现零人工,低成本的解决企业项目数据库因服务器宕机或其它原因导致的数据库异常终止.实现项目敏捷开发与上线的目的.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 原理: 1)监控MYSQL的运行状态; 2)Slave机器的IO和SQL状态都必须为YES,缺一不可; 注意,请结...
    361独家记忆阅读 946评论 0 1
  • 主:192.168.122.11从:192.168.122.22代理:192.168.122.33 主和从上分别是...
    不排版阅读 471评论 0 3
  • 严欣,一个阳光的女孩,暗恋了学长很多年,但却一次又一次的被伤害、打击,但其实幸福就在擦肩而过之后。
    運运阅读 62评论 0 1
  • 心理特点:1认知的发展。注意力有意注意发展并占主导,集中性、稳定性、注意的广度、分配、转移等都较低年级不同。有意记...
    梅溪湖肖老师520阅读 106评论 0 0
  • 不知道我从哪里看到了这样一篇文章,它讲的是一个家境 虽然贫穷但拥有高尚品德的孩子故事。 在一个偏僻的小山村的附近,...
    闫怡璇阅读 260评论 0 0