iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MyCat教程二:mysql主从复制实现
  • 649
分享到

MyCat教程二:mysql主从复制实现

MyCat教程二:mysql主从复制实现 2018-04-04 09:04:53 649人浏览 绘本
摘要

  单个Mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作。 1. 读写分离   原理:需要搭建主从模式,让主数据库(

  单个Mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作。

1. 读写分离

  原理:需要搭建主从模式,让主数据库(master)处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库(slave)处理 SELECT 查询操作。
  Mycat 配合数据库本身的复制功能,可以解决读写分离的问题。

2.主从备份概念

什么是主从备份: 就是一种主备模式的数据库应用.
主库(Master)数据与备库(Slave)数据完全一致.
实现数据的多重备份, 保证数据的安全.
可以在 Master[InnoDB]和 Slave[MyISAM]中使用不同的数据库引擎,实现读写的分离
InnoDB:支持事务处理
MyISAM:不支持事务处理

2.1 Mysql5.5, 5.6 版本后本身支持主从备份

  在老旧版本的 MySQL 数据库系统中,不支持主从备份,需要安装额外的 RPM 包.如果需要安装 RPM,只能在一个位置节点安装.

2.2 主从备份目的

2.2.1 实现主备模式

  保证数据的安全. 尽量避免数据丢失的可能.

2.2.2 实现读写分离

  使用不同的数据库引擎,实现读写分离.提高所有的操作效率.
  InnoDB 使用 DML 语法操作. MyISAM 使用 DQL 语法操作.

2.3 主从备份效果

2.3.1 主库操作同步到备库

  所有对 Master 的操作,都会同步到 Slave 中.如果 Master 和 Salve 天生上环境不同,那么对 Master 的操作,可能会在 Slave 中出现错误如: 在创建主从模式之前,Master 有 database : db1, db2, db3. Slave 有 database: db1, db2.创建主从模式.现在的情况 Master 和 Slave 天生不同.主从模式创建成功后,在 Master 中 drop database db3. Slave 中抛出数据库 SQL 异常.后续所有的命令不能同步.一旦出现错误. 只能重新实现主从模式.

2.4 主从模式下的逻辑图

在这里插入图片描述

3. MySQL主从模式搭建

3.1 安装MYSQL

mysql安装教程:
https://blog.csdn.net/weixin_45600622/article/details/102647528
环境地址:
主节点:192.168.88.180
从节点:192.168.88.181

在这里插入图片描述


在这里插入图片描述

3.2 主库配置修改(Master)

路径:/etc/my.cnf

3.2.1 server_id配置

本环境中 server_id 是 1
MySQL 服务唯一标识
配置要求:
server_id 任意配置,只要是数字即可
server_id Master 唯一标识数字必须小于 Slave 唯一标识数字.

在这里插入图片描述

3.2.2 log_bin配置

本环境中 log_bin 值 : master_log
开启日志功能以及日志文件命名,log_bin=master_log
变量的值就是日志文件名称.是日志文件名称的主体.
MySQL 数据库自动增加文件名后缀和文件类型.

在这里插入图片描述

3.2.3 重启mysql

service mysql restart
 

3.2.4 登录mysql

从mysql的安装路径下进入

./bin/mysql -uroot -h127.0.0.1 -p123456
 

在这里插入图片描述

3.2.5 创建用户

在 MySQL 数据库中,为不存在的用户授权,就是同步创建用户并授权.
此用户是从库访问主库使用的用户
ip 地址不能写为%. 因为主从备份中,当前创建的用户,是给从库 Slave 访问主库 Master使用的.用户必须有指定的访问地址.不能是通用地址.
grant all privileges on *.* to ‘username’@’ip’ identified by ‘passWord’ with grant option;
flush privileges;

grant all privileges on *.* to "myslave"@"192.168.88.181" identified by "myslave" with grant 
option;
flush privileges;
 

3.2.6 查看用户

use mysql;
select host, user from user;
 

在这里插入图片描述

3.2.7 查看 Master 信息

在这里插入图片描述

master_log.00003就是主从复制中从数据库要读取的日志文件。
注意:关闭防火墙或在防火墙中开放 3306 端口

3.3 从库配置修改(slave)

3.3.1 修改my.cnf的server_id

  从库的 server_id要比主库中的server_id的值要大

在这里插入图片描述
然后重启mysql服务

3.3.2 连接mysql服务

在这里插入图片描述

3.3.3 停止 Slave 功能

stop slave
 

3.3.4 配置主库信息

  需要修改的数据是依据 Master 信息修改的.ip 是 Master 所在物理机 IP. 用户名和密码是Master 提供的 Slave 访问用户名和密码. 日志文件是在 Master 中查看的主库信息提供的.在Master 中使用命令 show master status 查看日志文件名称.
change master to master_host=’ip’, master_user=’username’, master_password=’password’, master_log_file=’log_file_name’;

3.3.5 启动 Slave 功能

start slave;
 

3.3.6 查看 Slave 配置

show slave status G; # G 行转列
 

在这里插入图片描述

注意:如果输出中有如下提示:

Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL Server ids; these ids must be different for replication to work (or the –replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it). 
 

原因是以为两个数据库是克隆出来的,所以uuid是一致的,这时只需要删除掉一个uuid即可,具体如下:

在这里插入图片描述

auto.cnf 注释掉或者删除掉,重启mysql就会重新分配!

4. 主从测试

4.1 创建数据库同步

在master上新建一个数据库,然后查看slave中是否也有即可

在这里插入图片描述

create database demo2 default character set utf8;
 

在这里插入图片描述

4.2 创建table同步

create table t_user (id varchar(20),name varchar(20));
 

在这里插入图片描述

4.3 数据操作同步

insert into t_user (id,name)values("666","cxydmx");
 

在这里插入图片描述

通过演示我们发现主数据库的修改会及时的同步到从数据库,这样mysql的主从配置就OK了,好了本文就到此,下篇来详细介绍一下MyCat的安装与配置

 


关注微信公众号【程序员的梦想】,专注于Java,SpringBoot,SpringCloud,微服务,Docker以及前后端分离等全栈技术。

 

您可能感兴趣的文档:

--结束END--

本文标题: MyCat教程二:mysql主从复制实现

本文链接: https://www.lsjlt.com/news/1865.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MyCat教程二:mysql主从复制实现
      单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作。 1. 读写分离   原理:需要搭建主从模式,让主数据库(...
    99+
    2018-04-04
    MyCat教程二:mysql主从复制实现
  • MySQL主从复制(二)
    主从架构中:从node是不接受w操作的,否则可能会导致数据不一致。一、复制架构中应该注意的问题: 1.限制slave为只读模式 可以设置在启动参数中。 > show global variable...
    99+
    2022-10-18
  • mysql实现主从复制
    Mysql的 Replication 是一个异步的复制过程(mysql5.1.7以上版本分为异步复制和半同步两种模式),从一个 Mysql instace(我们称之为 Master)复制到另一个 ...
    99+
    2022-10-18
  • mysql主从复制的实现步骤
    目录mysql主从复制mysql主从复制的方式mysql主从复制的原理mysql的主从配置的具体实现方式1、 Master配置 2、 Slave配置 mysql主从复制 本来是在...
    99+
    2022-11-12
  • mysql实现主从复制的步骤
    本文主要给大家介绍mysql实现主从复制的步骤,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下mysql实现主从复制的步骤吧。mysql主从原理:1)...
    99+
    2022-10-18
  • mysql主从复制架构及实现
    mysql主从复制架构及实现 mysql主从复制配置 主节点: 启动二进制日志 为当前节点设置一个全局唯一的ID号(server-id) 创建有复制权限的用户账号(replication sl...
    99+
    2022-10-18
  • 基于 SSL 实现MySQL主从复制
    1、主服务器配置1)、在主服务器创建SSL/RSA文件 #在MySQL5.7之后,安装完毕MySQL会在data目录下自动生成,这里模拟没有这些文件 [[email protected] ~]# mysql_ssl_rsa_setup...
    99+
    2016-06-28
    基于 SSL 实现MySQL主从复制 数据库入门 数据库基础教程 数据库 mysql
  • MySQL主从复制的实现方法
    这篇文章给大家分享的是有关MySQL主从复制的实现方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。          &nbs...
    99+
    2022-10-18
  • MySQL主从复制搭建流程分步实现
    目录主从复制主从搭建配置主从复制的命令测试总结主从复制 主从也叫做(AB复制),允许一个服务器从一个服务器数据库(主服务器)的数据复制到一个或者多个mysql数据库服务器。 主从复制的优点有很多,包括横向扩展解决方案,数...
    99+
    2022-11-05
  • Redis教程(九):主从复制配置实例
    一、Redis的Replication: 这里首先需要说明的是,在Redis中配置Master-Slave模式真是太简单了。相信在阅读完这篇Blog之后你也可以轻松做到。这里我们还是先列出一些理论性...
    99+
    2022-06-04
    主从 实例 教程
  • Mycat中间件实现Mysql主从读写分离
    环境规划: IP地址 主机名 角色 备注 10.4.132.50 k8s01 mycat,master 10.4.132.42 k8s02 slave ...
    99+
    2022-10-18
  • 实战演示MySQL 5.7.17实现主从复制
    下文给大家带来有关实战演示MySQL 5.7.17实现主从复制内容,相信大家一定看过类似的文章。我们给大家带来的有何不同呢?一起来看看正文部分吧,相信看完实战演示MySQL 5.7.17实现主从复制你一定会...
    99+
    2022-10-18
  • 一文教会你在Docker容器中实现Mysql主从复制
    目录一 主从复制概念二 主从复制的优势三 docker容器实现mysql主从复制3.1 创建主服务器容器3.2 新建主配置文件 my.cnf3.3 重启master容器实例3.4 进入mysql-master容器3.5 ...
    99+
    2022-11-29
    docker搭建mysql主从 docker mysql 主从配置 docker容器mysql主从复制
  • mysql主从复制配置过程
    主库配置 1. 配置mysql vim /etc/my.cn # 在文件中增加以下内容 server-id=1 # 保证server id唯一 log-bin = /var/lib/mysql/mysql-bin...
    99+
    2022-05-23
    mysql 主从复制 mysql 主从复制配置
  • Mysql主从复制搭建过程
    这篇文章主要讲解了“Mysql主从复制搭建过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql主从复制搭建过程”吧! 一、相关概念mysql主从复...
    99+
    2022-10-18
  • MYSQL主从复制部署流程
    环境准备:部署一主一从两台服务器,实现主从复制,主库要开启binlog,主库和从库的Server-id要不同主库:[root@db01 ~]# hostname -I 10.0...
    99+
    2022-10-18
  • MyCat怎么实现MySQL一主两从读写分离
    这篇文章主要介绍“MyCat怎么实现MySQL一主两从读写分离”,在日常操作中,相信很多人在MyCat怎么实现MySQL一主两从读写分离问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2022-10-18
  • MyCat如何实现MySQL双主一从读写分离
    这篇文章给大家分享的是有关MyCat如何实现MySQL双主一从读写分离的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1)配置server.xml<user nam...
    99+
    2022-10-18
  • 数据库学习之十二:mysql主从复制
    十二、mysql主从复制 1、主从复制原理 主从复制的前提: 1两台mysql实例(多台物理机,或者多实例) 2主库要开启二进制日志 3主库要提供复制相关用户,replication slave,一个比较特殊的权限。 grant ...
    99+
    2019-12-13
    数据库学习之十二:mysql主从复制
  • Windows环境下配置MySQL主从复制详细教程
    一、下载mysql 下载地址:MySQL :: MySQL Community Downloads 点击箭头所指  2、默认页面是下载mysql8,如果想下载mysql5点击箭头所指 点击箭头所指选择需要的版本 4、点击箭头所指可以选择...
    99+
    2023-09-05
    mysql 数据库 java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作