美文网首页
13-Linux主主一键配置脚本

13-Linux主主一键配置脚本

作者: 吕小凯 | 来源:发表于2019-07-29 13:58 被阅读0次
#!/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

相关文章

  • linux安装ssr

    CentOS/Debian/Ubuntu ShadowsocksR单/多端口一键管理脚本: 主用代码: 备用代码:...

  • ansible部署redis5.x集群

    0.剧本说明 1.目录结构 2.配置文件jinja模版 主节点配置模版 从节点配置模版 3.启动脚本 主节点启动脚...

  • Linux服务器冷备同步脚本

    Linux服务器冷备同步脚本 脚本脚本详情 详细代码 vim RsyncBackFile.py 配置文件说明 主配...

  • Conetos7 使用teddysun一键脚本搭建SSR

    安装 使用teddysun一键脚本 配置 启动

  • 一键安装 Fikker 缓存(CDN) - Linux 版

    1、一键安装 2、远程登录+配置 3、其它常用一键脚本 1、一键安装脚本,直接拷贝下面的命令组合到Linux终端执...

  • 配置:mysql [主-从]&[主-主]

    主数据库配置 主数据库配置备份用户 在 主数据库 上配置 备份用户 主数据库配置my.cnf 然后重启 mysql...

  • 批量检测端口连通性

    主脚本check.sh: 这里是配合jenkins 用的, jenkins配置如下: jenkins job的 ...

  • MySQL主主集群配置

    一、主主复制: Mysql主主集群中,2台服务器之间没有明显的地位差距, 两者都可以同步对方的内容 一般的格局如下...

  • MySql配置主主复制

    服务器A:192.168.99.24服务器B:10.255.255.24 服务器A mysql配置 服务器B my...

  • mysql主从、主主配置

    引言 实际生产中要求数据库的高可用性,就要考虑mysql的主从、主主。若针对的是上云的机器,比如使用阿里云,那可以...

网友评论

      本文标题:13-Linux主主一键配置脚本

      本文链接:https://www.haomeiwen.com/subject/ucxnrctx.html