mysql双主+keepalived【转】
简单原理
1、在两台服务器上分别部署双主keepalived,主keepalived会在当前服务器配置虚拟IP用于mysql对外提供服务
2、在两台服务器上分别部署主主mysql,用于故障切换
3、当mysql服务器挂掉后,主keepalived会降低当前机器权重,备keepalived服务器会把虚拟IP抢过来配置在备服务器上,使备服务器的mysql能接替工作继续对外提供服务
4、由于keepalived只能检测服务器是否宕机来实现故障自动切换,但不能针对应用级别(mysql)的检测,因此,需要编写脚本实时监测mysql服务是否运行正常,当检测mysql运行不正常时就降低权重,来实现故障自动切换
角色分配:
| IP地址 | 部署应用 |
|---|---|
| 192.168.1.200 | mysql001+keepalived01 |
| 192.168.1.201 | mysql002+keepalived02 |
虚拟IP192.168.1.100初始配置在keepalived01,无需手动配置,keepalived会自动配置
准备工作:
#关闭iptables
service iptables stop
chkconfig iptables off
#关闭selinux
setenforce 0
修改/etc/selinux/config文件,将SELINUX=enforcing改为SELINUX=disabled
#同步主机时间
ntpdate 202.120.2.101
=====================================================================
一、配置mysql双主服务
#用yum安装mysql服务
yum install MySQL-shared-compat-5.6.23-1.el6.x86_64.rpm
yum install MySQL-server-5.6.23-1.el6.x86_64.rpm
yum install MySQL-client-5.6.23-1.el6.x86_64.rpm
yum install MySQL-devel-5.6.23-1.el6.x86_64.rpm
yum install MySQL-shared-5.6.23-1.el6.x86_64.rpm
#创建数据目录
mkdir -pv /home/mydata/data
chown -R mysql.mysql /home/mydata
chmod -R +w /home/mydata
#修改主配置文件
vi /etc/my.cnf
#在mysql001上
[mysqld]
datadir = /home/mydata/data #mysql的数据存放位置
port = 3306 #mysql的端口号
socket = /var/lib/mysql/mysql.sock
log-bin = master-bin
server_id = 1 #mysql的ID号
log-bin = mysql-bin
relay-log = mysql-relay-bin
replicate-wild-ignore-table = mysql.%
replicate-wild-ignore-table = test.%
replicate-wild-ignore-table = information_schema.%
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 256
pid-file = /home/mydata/data/mysql.pid
sort_buffer_size = 1M
read_buffer_size = 1M
read_rnd_buffer_size = 1M
myisam_sort_buffer_size = 64M
thread_cache_size = 8
query_cache_size= 16M
innodb_file_per_table = on
thread_concurrency = 8
skip_name_resolve = on
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
#在mysql002上
[mysqld]
datadir = /home/mydata/data
port = 3306
socket = /var/lib/mysql/mysql.sock
log-bin = master-bin
server_id = 2
log-bin = mysql-bin
relay-log = mysql-relay-bin
replicate-wild-ignore-table = mysql.%
replicate-wild-ignore-table = test.%
replicate-wild-ignore-table = information_schema.%
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 256
pid-file = /home/mydata/data/mysql.pid
sort_buffer_size = 1M
read_buffer_size = 1M
read_rnd_buffer_size = 1M
myisam_sort_buffer_size = 64M
thread_cache_size = 8
query_cache_size= 16M
innodb_file_per_table = on
thread_concurrency = 8
skip_name_resolve = on
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
#初始化mysql
/usr/bin/mysql_install_db --datadir=/home/mydata/data --user=mysql
#相互为对方主机授权复制账号
grant replication slave on *.* to 'repl_user'@'192.168.%.%' identified by 'repl_passwd';
#查看master的状态
show master status;
#授权给check用户,用来检测mysql
grant replication client on *.* to 'check'@'localhost' identified by 'check';
#配置对方为自己的master
在mysql001上:
change master to \
master_host='192.168.1.201',
master_user='repl_user',
master_password='repl_passwd',
master_log_file='mysql-bin.000003',
master_log_pos=333; 【这个数字是上面show master status;】
在mysql002上:
change master to \
master_host='192.168.1.200',
master_user='repl_user',
master_password='repl_passwd',
master_log_file='mysql-bin.000003',
master_log_pos=333;
#启动服务,两台机器上都执行
start slave;
#查看是否运行正常
show slave status\G;
二、配置keepalived
在mysql001上:
vi /etc/keepalived/keepalived.conf
#######################################################
! Configuration File for keepalived
global_defs {
notification_email {
2011820123@qq.com
}
notification_email_from keepalived@localhost
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id MYSQL_DEVEL
}
vrrp_script check_mysqld { #设置检测脚本
script "/etc/keepalived/check.sh" #指定检测脚本的存放位置
interval 2 #间隔时间
weight -51 #权重,降权51
}
vrrp_instance VI_1 {
state BACKUP #注意,这里两台服务器都要是BACKUP
interface em1
virtual_router_id 60
priority 100
nopreempt
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
check_mysqld
}
virtual_ipaddress {
192.168.1.100 #虚拟IP
}
}
#######################################################
在mysql002上:
vi /etc/keepalived/keepalived.conf
#######################################################
! Configuration File for keepalived
global_defs {
notification_email {
2011820123@qq.com
}
notification_email_from keepalived@localhost
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id MYSQL_DEVEL
}
vrrp_script check_mysqld {
script "/etc/keepalived/check.sh"
interval 2
weight -51
}
vrrp_instance VI_1 {
state BACKUP #注意,这里两台服务器都要是BACKUP
interface em1
virtual_router_id 60
priority 90
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
check_mysqld
}
virtual_ipaddress {
192.168.1.100
}
}
#######################################################
"state BACKUP”,在这里两台服务器要都设为BACKUP,如果一台是MASTER,另一台是BACKUP,那么当MASTER恢复数据之后,主keepalived要切换到MASTER上,这样BACKUP上的数据就会丢失。因此在这两台mysql服务器上都设置成BACKUP,那么当MASTER恢复后,不会自动切换回去
#重启keepalived服务
service keepalived restart
五、编辑mysql监控脚本
vi /etc/keepalived/check.sh
#######################################################
#/bin/bash
live=`ss -tnlp | grep 3306 | wc -l` #检查mysql的3306端口是否存在
yes=`mysql -ucheck -pcheck -e "show slave status\G" | head -13 | tail -2 | awk -F: '{print $2}' | grep Yes | wc -l` #检查‘show slave status’是否正常
if [ $live -ge 1 ];then #如果$live大于等于1,执行下步操作
if [ $yes -eq 2 ];then #如果‘show slave status’出现两个yes,就退出
exit 0
else
/etc/init.d/keepalived restart #否则,重启keepalived服务,退出
exit 1
fi
else
/etc/init.d/keepalived restart #如果$live小于1,那么重启keepalived服务
exit 1
fi
#######################################################
#给脚本执行权限
chmod +x /etc/keepalived/check.sh
转自:
mysql双主+keepalived - 今日头条(www.toutiao.com)
http://www.toutiao.com/i6384270119261962753/
mysql双主+keepalived【转】的更多相关文章
- mysql双主+keepalived
环境 OS: centos7Mysql 版本: mysql 5.7Keepalived: keepalived-1.2.20Mysql-vip:192.168.41.100Mysql-master1: ...
- MySQL 双主+keepalived 详细文档 M-M+keepalived
1. 操作系统,系统环境,目结结构,用户,权限,日志路径,脚本2. 配置规范化 1.1 操作系统准备 操作系统 Kylin Linux release 3.3.1707 (Core)数据库版本 mys ...
- Mysql双主 keepalived+lvs实现mysql高可用性
MySQL复制 能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.但是MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现 ...
- 004.MySQL双主+Keepalived高可用
一 基础环境 主机名 系统版本 MySQL版本 主机IP Master01 CentOS 6.8 MySQL 5.6 172.24.8.10 Master02 CentOS 6.8 MySQL 5.6 ...
- centos7下mysql双主+keepalived
一.keepalived简介 keepalived是vrrp协议的实现,原生设计目的是为了高可用ipvs服务,keepalived能够配置文件中的定义生成ipvs规则,并能够对各RS的健康状态进行检测 ...
- MySQL双主+keepalived实现高可用实现(热备)
环境:centos6.7 最小化安装 192.168.100.152 master 主192.168.100.153 slave 从192.168.100.132 v_ip 浮动IP 配置ssh密码登 ...
- mysql双主+keepalived架构
架构展示 操作系统 centos6.5 数据库 mysql5.7 master1 10.0.254.148 master2 10.0.254.147 VIP 10.0.254.88 (keepaliv ...
- MySQL双主+Keepalived高可用
原文转自:https://www.cnblogs.com/itzgr/p/10233932.html作者:木二 目录 一 基础环境 二 实际部署 2.1 安装MySQL 2.2 初始化MySQL 2. ...
- Mysql 双主--keepalived
简介 编辑 Keepalived的作用是检测服务器的状态,如果有一台web服务器宕机,或工作出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除,同时使用其他服务器代替该服务器的工作 ...
随机推荐
- 第一个sprint冲刺第一阶段
会议地址:男生宿舍1栋B4014 会议内容:讨论如何完成产品 成员:李新,朱浩龙,陈俊金,叶煜稳,林德麟 困难:对于做成一个手机APP,尚未掌握:成员尚在学习中 master:陈俊金
- C#简述(一)
详情请参考:http://www.runoob.com/csharp/csharp-tutorial.html 1.C# 是一个简单的.现代的.通用的.面向对象的编程语言,它是由微软(Microsof ...
- CAS单点登录的时候出现票根'ST-xxxxxx-cas'不符合目标服务
CAS单点登录遇到问题:票根'ST-xxxxxx-cas'不符合目标服务,原因出在linux 时间未同步,差了3分钟 .
- Spring之jdbcTemplate:增删改
JdbcTemplate增删改数据操作步骤:1.导入jar包:2.设置数据库信息:3.设置数据源:4.调用jdbcTemplate对象中的方法实现操作 package helloworld.jdbcT ...
- poj2991 Crane(线段树)
Description ACM has bought a new crane (crane -- jeřáb) . The crane consists of n segments of variou ...
- tomcat 启用NIO
从Tomcat6.0以后, Java开发者很容易就可以是用NIO的技术来提升tomcat的并发处理能力. <Connector port="8080" protocol=&q ...
- Single VIP LLB and SLB config
Single VIP LLB and SLB config >>>>>>>>>>>>>>>>>&g ...
- 洛谷P4234 最小差值生成树(LCT,生成树)
洛谷题目传送门 和魔法森林有点像,都是动态维护最小生成树(可参考一下Blog的LCT总结相关部分) 至于从小到大还是从大到小当然无所谓啦,我是从小到大排序,每次枚举边,还没连通就连,已连通就替换环上最 ...
- winform里宿主WCF,并传递winform变量给WCF
最近客户要求把服务器端程序里的二个功能用service的方式提供出来,方便调用.首先想着单独建一个wcf 服务的项目,但是因为要用到server端程序winform里的变量,因此只能在winform里 ...
- CRM 报表导出excel时指定sheet名
如图所示,设置PageName即可: 这样导出excel时,sheet的名就有了: