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. 代数&数论趣题集萃

    暑假总不能只学习平面几何.所以这里也收集一些有趣的代数题或数论题,同时记下解法的一些提示.给未来的自己复习参考用. 多图片预警(请注意流量) 目录: Part 0:其他(8) Part 1:不等式(1 ...

  2. Bootstrap 提示工具(Tooltip)插件

    一.提示工具(Tooltip)插件根据需求生成内容和标记,默认情况下是把提示工具(tooltip)放在它们的触发元素后面. 有以下两种方式添加提示工具(tooltip): 1.通过data属性:如需添 ...

  3. java.sql.SQLException: Access denied for user 'xxx'@'localhost' (using password: YES)

    java.sql.SQLException: Access denied for user 'xxx'@'localhost' (using password: YES) at com.mysql.c ...

  4. python 基础笔记-函数

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段·. 好处为: 一可以把程序中相对独立的功能模块抽取出来,减少重读代码的编写: 二是将来可以以重复的使用这些功能模块    定义一个函数 ...

  5. Java反射之Bean修改更新属性值等工具类

    package com.bocean.util; import java.lang.annotation.Annotation; import java.lang.reflect.Field; imp ...

  6. java.lang.IllegalArgumentException: Invalid character found in the request target. The valid charact

    线上环境中部署的 Tomcat 项目,出现部分页面无法打开的情况,但本地环境是好的.经过排查发现,本地 Tomcat版本为 7.0.77,而线上版本为 7.0.88.报错的具体描述为java.lang ...

  7. 每天一道Rust-LeetCode(2019-06-01)

    每天一道Rust-LeetCode(2019-06-01) 坚持每天一道题,刷题学习Rust. 题目描述 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的, ...

  8. Linux修复小技巧

    在重启时不能进入系统,出现以下提示符时.此时输入root密码进入紧急模式,将/etc/fstab文件中除 “/”(根)以外的挂载点全部注释,进系统后在修复排错

  9. ESA2GJK1DH1K升级篇: IAP详解

    前言: 源码下载链接: https://gitee.com/yang456/STM32_IAP_Learn.git 后期所有出售的升级程序皆在此代码之上进行优化和开发 请必须把此文章各个的地方的说明看 ...

  10. [ZJJOI2013]K大数查询 整体二分

    [ZJJOI2013]K大数查询 链接 luogu 思路 整体二分. 代码 #include <bits/stdc++.h> #define ll long long using name ...