echo编辑整理,欢迎转载,转载请声明文章来源。欢迎添加echo微信(微信号:t2421499075)交流学习。 百战不败,依不自称常胜,百败不颓,依能奋力前行。——这才是真正的堪称强大!!!


本文主要为了记录MySQL搭建读写分离的操作,是本人的操作纪实,并没有详细讲解其中的原理和操作设置,如果需要详细解释的,不建议阅读。

环境准备:

linux系统版本 对应服务器地址 数据库 版本
CentOS7 192.168.222.132 MySQL 5.6
CentOS7 192.168.222.133 MySQL 5.6
CentOS7 192.168.222.134 MySQL 5.6

第一步:建立时间同步环境

  • 使用yum安装npt
yum install ntp –y
  • 安装完成之后修改ntp对应的配置文件
vi /etc/ntp.conf
  • 添加如下配置:图片中地址,对应我们自己服务器的地址
restrict 192.168.222.132 mask 255.255.255.0 nomodify notrap
server 127.127.1.0
fudge 127.127.1.0 stratum 8

  • 启动ntp服务
systemctl start ntpd
  • 检验ntp是否成功安装运行,如果正常工作我们可以得到如下信息
ntpq -p

将我们三台服务全部做以上配置,配置完成之后,我们就可以开始设置主mysql服务器了

第二步:配置 MySQL 主服务器

  • 打开my.cnf配置文件,进行如下配置
# 打开文件
vi /etc/my.cnf

找到配置文件中的这一段,然后按照下面的配置进行修改

server-id=132   # 使用ip的后端作为我们的主服务id
log_bin=mysql-bin # 开启MySQ二进制日志系统。
  • 登录mysql,然后获取数据库列表
mysql -uroot -P3306 -p123456 -h192.168.222.132

show databases;

binlog-do-db=test  # 需要同步的数据库名test,其他的数据库不同步。
binlog-ignore-db=mysql #不同步mysql系统数据库,每一个数据库对应一行。
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
  • 配置完成,重复服务
service mysql restart
  • 查看我们的配置是否成功
show master status;

如果显示结果和我们配置一致证明我们的主服务器配置已经成功啦!可以进行从服务器的配置

配置从服务器

  • 打开my.cnf配置文件,进行如下配置
# 打开文件
vi /etc/my.cnf

找到配置文件中的这一段,然后按照下面的配置进行修改

server-id=133   # 使用ip的后端作为我们的主服务id
log_bin=mysql-bin # 开启MySQ二进制日志系统。
  • 登录mysql,然后获取数据库列表
mysql -uroot -P3306 -p123456 -h192.168.222.133

show databases;

binlog-do-db=test  # 需要同步的数据库名test,其他的数据库不同步。
binlog-ignore-db=mysql #不同步mysql系统数据库,每一个数据库对应一行。
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
  • 配置完成,重复服务
service mysql restart

从服务器需要做的关键操作

  • 为从服务器创建一个可以登录主服务器的账号。
# 登录主服务器,创建一个新账号
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.222.133' IDENTIFIED BY '123456';
# 刷新权限
FLUSH PRIVILEGES;
  • 然后使用root用户连接mysql,再执行一下语句
change master to
master_host='192.168.222.132',
master_user='slave',
master_password='123456',
master_log_file='mysql-bin.000011',
master_log_pos=1243;
  • 配置完成之后,启动从服务器
start slave;
  • 查看从服务器启动状态
show slave status \G;



出现上面这两个“Yes”就证明已经配置成功了

  • 如果发现配置不对,需要先停掉从服务器
stop slave;
  • 然后重置从服务器
reset slave;

采坑解决



如果出现如上报错,我们需要先停止从服务器。该问题引起的原因是我之前安装数据库的时候并没有发现他们的版本不一致导致的,停机更新版本之后再次按照下面步骤操作就好了。

# 先停掉从服务器
stop slave;
# 重置从服务器
reset slave;
# 然后排查配置的问题,重新配置一遍
change master to
master_host='192.168.222.132',
master_user='slave',
master_password='123456',
master_log_file='mysql-bin.000011',
master_log_pos=709;
# 再次启动
start slave;
# 查看服务器状态
show slave status \G;

尝试创建一个表,查看是否同步

CREATE TABLE `user` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增id',
`user_name` varchar(255) DEFAULT NULL,
`pass_word` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

到这里我们已经成功啦!


注意:

我们配置第三台服务的时候,需要从新创建一个给第三台服务器访问的主服务器的账号。同时,由于我们是在本地虚拟机上安装的读写分离环境,所以每一次启动mysql或者关闭虚拟机都会导致mysql的position改变,所以我们要跟随着配置变化,每次启动读写环境前检查一下,修改配置和上面采坑解决的步骤一直。


做一个有底线的博客主

Mycat分布式数据库架构解决方案--搭建MySQL读写分离环境--一主多从的更多相关文章

  1. Mycat分布式数据库架构解决方案--Mycat实现读写分离

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 安装完 ...

  2. Mycat分布式数据库架构解决方案--Mycat实现数据库分表

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 准备工 ...

  3. Mycat分布式数据库架构解决方案--schema.xml详解

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文件 ...

  4. Mycat分布式数据库架构解决方案--Server.xml详解

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文件 ...

  5. Mycat分布式数据库架构解决方案--rule.xml详解

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文件 ...

  6. Mycat分布式数据库架构解决方案--Mycat的介绍

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 如果我 ...

  7. Mycat分布式数据库架构解决方案--Linux安装运行Mycat

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! Myc ...

  8. Mycat分布式数据库架构解决方案--配置defaultAccount属性报错解决方案

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文章 ...

  9. 提高性能,MySQL 读写分离环境搭建(一)

    这是松哥之前一个零散的笔记,整理出来分享给大伙! MySQL 读写分离在互联网项目中应该算是一个非常常见的需求了.受困于 Linux 和 MySQL 版本问题,很多人经常会搭建失败,今天松哥就给大伙举 ...

随机推荐

  1. destoon开发笔记-调取资讯标题图

    今天刚申请博客园的博客,申请速度挺快的.之前我的文章都是发在自己搭建的博客网站,但是是香港服务器,不想续费了,所以就关闭了.之前的数据也没有了,挺可惜了.不过既然加入博客园的大家庭,我就在这每天记录工 ...

  2. centos7运维记录文档

    问题一:故障记录时间2019年4月4日,查看系统日志报错如下: tail -f /var/log/messages Apr 4 16:29:16 localhost kernel: tracker-e ...

  3. shell脚本启动所有集群节点

    #profile变量追加到.bashrc中 cat /etc/profile >> ~/.bashrc #start-all-cluster.sh  启动脚本 #!/bin/bash ec ...

  4. Comet OJ 夏季欢乐赛 分配学号

    Comet OJ 夏季欢乐赛 H 分配学号 题目传送门 题目描述 今天,是JWJU给同学们分配学号的一天!为了让大家尽可能的得到自己想要的学号,鸡尾酒让大家先从 [1,10^{18}][1,1018] ...

  5. 【myBatis】It's likely that neither a Result Type nor a Result Map was specified.

    因为mapper.xml里把resultType写成了parameterType

  6. Scheme、Claim、ClaimsIdentity、ClaimsPrincipal介绍

    在 token 创建.校验的整个生命周期中,都涉及到了  Scheme.Claim.ClaimsIdentity.ClaimsPrincipal 这些概念,如果你之前有使用过微软的 Identity ...

  7. git bisect

    reference : http://www.ruanyifeng.com/blog/2018/12/git-bisect.html git bisect 命令教程 作者: [12]阮一峰 日期: [ ...

  8. django数据请求

    目录 数据请求: 静态文件加载 form表单 : 数据请求: request方法: 数据请求: 静态文件加载 静态文件加载: 1.默认情况下所有的html文件都是放在templates文件夹内 静态文 ...

  9. keepalived 配置文件解析

    ! Configuration File for keepalived global_defs { #全局定义部分 notification_email { #设置报警邮件地址,可设置多个 acass ...

  10. 关于getClass(),Object.class,getClassLoader的理解

    1.对Class类的理解:Class类包含了类的信息,如构造方法.方法.属性,可用于反射.以下是所有方法 2.获取Class类对象的几种方法: Test test = new Test(); (1). ...