MySQL双主+keepalived实现高可用实现(热备)
环境:centos6.7 最小化安装
192.168.100.152 master 主
192.168.100.153 slave	从
192.168.100.132 v_ip	浮动IP
配置ssh密码登录,关闭selinux,关闭防火墙
1、安装mysql
#yum install mysql* -y
2、配置mysql配置文件
#配置/etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
server-id = 1	//这个ID是mysql数据库的唯一标识符
log-bin = mysql-bin
log_bin_trust_function_creators = 1
binlog_format = mixed
relay-log = relay-bin
relay-log-index = slave-relay-bin.index
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
default-character-set=utf8
#slave_skip_errors = 1146
#binlog-ignore-db=mysql
[client]
default-character-set=utf8
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
3、启动mysqld服务(启动mysql数据库)
#service mysqld start
#chkconfig mysqld on
4、设置mysql数据库root密码
#mysqladmin -uroot password '12345678'
4、创建授权用户,配置同步。
#####################################################################################################################################################################################
master上:
mysql>grant replication slave on *.* to 'rep'@'192.168.100.153' identified by '12345678';
查看slave上的mysql的master_log_file和master_log_pos;
master_log_file=`mysql -uroot -p12345678-e "show master status;" | grep mysql | cut -f 1`
master_log_pos=`mysql -uroot -p12345678 -e "show master status;" | grep mysql | cut -f 2`
mysql>change master to master_host='192.168.100.153',master_user='rep',master_password='12345678',master_log_file="\'$fsmanager_log_file\'",master_log_pos=$fsmanager_log_pos;
mysql>start slave;
service mysqld restart
slave上:
mysql>grant replication slave on *.* to 'rep'@'192.168.100.152' identified by '12345678';
查看slave上的mysql的master_log_file和master_log_pos
master_log_file=`mysql -uroot -p12345678 -e "show master status;" | grep mysql | cut -f 1`
master_log_pos=`mysql -uroot -p12345678 -e "show master status;" | grep mysql | cut -f 2`
mysql>change master to master_host='192.168.100.152',master_user='rep',master_password='12345678',master_log_file="\'$fsmanager_log_file\'",master_log_pos=$fsmanager_log_pos;
mysql>start slave;
service mysqld restart
#####################################################################################################################################################################################
mysql -uroot -p12345678 -e "grant all privileges on *.* to 'root'@'v_ip' identified by '12345678' with grant option;"
mysql -uroot -p12345678 -e "grant all privileges on *.* to 'root'@'masterr' identified by '12345678' with grant option;"
############# 配置高可用 #########
1、安装
#yum install -y kernel-devel openssl-devel popt-devel keepalived
#######################################################
master上:
vim /etc/keepalived/keepalived.conf
global_defs {
router_id mysql1
}
vrrp_script chk_mysql {
script "/etc/keepalived/check_mysql.sh"
interval 3
}
vrrp_instance VI_1 {
state MASTER	//只有MASTER和BACKUP 两种状态,都必须大写。
interface eth0	//进行通信的端口
virtual_router_id 146	//此ID是网络中的唯一 0--255之间
priority 100	//#权重,数值越大,权重越大。MASTER大于SLAVE
advert_int 1	//MASTER和SLAVE负载均衡器之间同步检查的时间间隔。单位是:秒
authentication {	//MASTER和SLAVE的认证方式
auth_type PASS
auth_pass andrew
}
virtual_ipaddress {	//用到的浮动IP组
192.168.100.132
}
track_script {
chk_mysql
}
}
slave上:
global_defs {
router_id mysql2
}
vrrp_script chk_mysql {
script "/etc/keepalived/check_mysql.sh"
interval 3
}
vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 146
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass andrew
}
virtual_ipaddress {
192.168.100.132
}
track_script {
chk_mysql
}
}
#######################################################
cat >/etc/keepalived/check_mysql.sh<<-EOF
#!/bin/bash
d=`date --date today +%Y%m%d_%H:%M:%S`
n=`ps -C mysqld --no-heading|wc -l`
if [ $n -eq "0" ]; then
service mysqld start
n2=`ps -C mysqld --no-heading|wc -l`
if [ $n2 -eq "0" ]; then
echo "$d mysql down,keepalived will stop" >> /var/log/check_mysql.log
service keepalived stop
fi
fi
EOF
chmod 755 /etc/keepalived/check_mysql.sh
service keepalived restart
chkconfig keepalived on
MySQL双主+keepalived实现高可用实现(热备)的更多相关文章
- 通过keepalived搭建MySQL双主模式的高可用集群系统
		
1. 配置MySQL双主模式 1.修改my.cnf配置文件 默认情况下,MySQL的配置文件是/etc/my.cnf,在配置文件的[mysqld]段添加如下内容: server-id=1 log-bi ...
 - mysql双主+keepalived【转】
		
简单原理 1.在两台服务器上分别部署双主keepalived,主keepalived会在当前服务器配置虚拟IP用于mysql对外提供服务 2.在两台服务器上分别部署主主mysql,用于故障切换 3.当 ...
 - heartbeat+DRBD 高可用 双机热备
		
heartbeat+DRBD 高可用 双机热备 原创博文http://www.cnblogs.com/elvi/p/7658109.html ## heartbeat+DRBD 高可用 双机热备 # ...
 - Nginx+keepalived 高可用双机热备(主从模式/双主模式)
		
基础介绍负载均衡技术对于一个网站尤其是大型网站的web服务器集群来说是至关重要的!做好负载均衡架构,可以实现故障转移和高可用环境,避免单点故障,保证网站健康持续运行. 关于负载均衡介绍,可以参考:li ...
 - 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 ...
 - keepalived + haproxy 实现web 双主模型的高可用负载均衡--转
		
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://xz159065974.blog.51cto.com/8618592/140581 ...
 - Mysql双主  keepalived+lvs实现mysql高可用性
		
MySQL复制 能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.但是MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现 ...
 - centos7下mysql双主+keepalived
		
一.keepalived简介 keepalived是vrrp协议的实现,原生设计目的是为了高可用ipvs服务,keepalived能够配置文件中的定义生成ipvs规则,并能够对各RS的健康状态进行检测 ...
 
随机推荐
- Object 的方法总结
			
1.Object.create() Object.create()方法创建一个新对象,使用现有的对象来提供新创建的对象的__proto__. 用法:Object.create( proto, [pro ...
 - github 下载子目录内容 亲测可用!
			
下载我的LYBTouchID项目的Kit目录内容 (1)在github上点开这个目录,浏览器地址栏可以得到这个地址 https://github.com/Liuyubao/LYBTouchID/tre ...
 - MySQL的统计信息学习总结
			
统计信息概念 MySQL统计信息是指数据库通过采样.统计出来的表.索引的相关信息,例如,表的记录数.聚集索引page个数.字段的Cardinality.....MySQL在生成执行计划时,需要根据索引 ...
 - ETCD节点故障恢复
			
我在微服务组里面主要负责配置中心的构建,我们的配置中心使用到了ETCD.在我们的内网环境中搭建了三个节点的ETCD,不过这三个节点的ETCD都搭建在同一台机器上.后来机器资源不够了系统直接kill了E ...
 - 学习笔记04IIS
			
IIS机制:1.能监听端口,获取socket的客户端对象2.获取请求报文,将请求报文变成对象.3.处理请求报文,通过HttpApplication.ProcessRequest方法来处理HttpCon ...
 - golang 包依赖管理 godep 使用
			
介绍: godep是解决包依赖的管理工具,目前最主流的一种,原理是扫描记录版本控制的信息,并在go命令前加壳来做到依赖管理. 1.安装: go get github.com/tools/godep 2 ...
 - [考试反思]1005csp-s模拟测试61:休止
			
连续不知道多少场了,都是一场10名以内一场20以外...波动极大...还极有规律... 拿到这套题,看到T1大模拟无话可说. 然后考场上我觉得T2很简单....然后就码了两个半小时. T3数据水了暴力 ...
 - 设置eclipse的字体大小
			
window->preferences->general->Appearance->Colors and Fonts->basic->text font->点 ...
 - 深入理解计算机系统 第二章 信息的表示和处理 part1
			
欣哥划的重点: 第二章比较难,建议至少掌握下面几个知识点: 1. 字节顺序 : 大端和小端 2. 运行 图2-24, 图2-25程序 show-bytes.c 观察结果,看看有什么问题 3. 理解布尔 ...
 - Netty处理器重要概念
			
1.Netty的处理器可以分为两类:入站处理器和出战处理器 2.入站处理器顶层是ChannelInboundHandler,出战处理器顶层是ChannelOutboundHandler 3.数据处理时 ...