mysql实现主从复制的日志是哪种_Redis主从复制

mysql实现主从复制的日志是哪种_Redis主从复制Mysql实现主从复制

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前言

Mysql主从同步,要求需要先搭建至少两个mysql实例,一主一从,使用推荐Docker搭建Mysql《Docker部署安装Mysql》

1、原理

在这里插入图片描述
mysql主(称master)从(称slave)复制的原理:

  • master将数据改变记录到二进制日志(binary log)中,也就是配置文件log-bin指定的文件(这些记录叫做二进制日志事件,binary log events)
  • slave将master的binary log events拷贝到它的中继日志(relay log)
  • slave重做中继日志中的事件,将改变反映它自己的数据(数据重演)

主从配置需要注意的地方:

  • 主DB server和从DB server数据库的版本一致
  • 主DB server和从DB server数据库数据一致
  • 主DB server开启二进制日志,主DB server和从DB server的server_id都必须唯一

2、数据库搭建

事先搭建好两个数据库,分别为端口3306、3307,并且分别创建数据库test
数据库的容器名称分别为;mysql-3306、mysql-3307;

3、主库搭建配置

主数据库使用docker搭建,端口为3306

1、修改配置文件:

在搭建好基础Mysql以后,修改配置文件,在原有基础上加入如下内容:

[mysqld]
server-id=1  #服务id,不可重复
log-bin=mysql-bin  #开启二进制日志,设置路径
#是否只读,1 代表只读, 0 代表读写
read-only=0
#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行(先建好库),不指定则同步整个数据源
binlog-do-db=test
#不同步系统数据库
binlog-ignore-db=mysql
binlog-ignore-db=sys
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema

2、重启数据库:

docker restart mysql-3306

4、从库搭建配置

主数据库使用docker搭建,端口为3306

1、修改配置文件:
在搭建好基础Mysql以后,修改配置文件,在原有基础上加入如下内容:

[mysqld]
#服务id,不可重复
server-id=2 
# 开启二进制日志
log-bin=mysql-bin

2、重启数据库:

docker restart mysql-3307

3、获取master相关信息:

在3306端口的主库执行:SHOW MASTER STATUS;查看新的主库信息,结果如下:

在这里插入图片描述

4、从库连接主库配置:

连接语句:

-- 从库SQL语句:
CHANGE MASTER TO 
master_host='162.10.1.35', #主库所在地址
master_user='root', -- 前面主库设置的用户、密码
master_password='123456', 
master_port=3306, -- 主库端口
master_log_file='mysql-bin.000001',  -- 前面主库的File信息
master_log_pos=157; -- 前面主库的Position信息 

启动同步语句:

-- 启动同步 SQL语句: stop:停止,reset:重启
start slave; 

5、从库状态检测:

检测语句:

show slave status;

效果:

在这里插入图片描述注意: 当Slave_IO_Running 和 Slave_SQL_Running: 均为YES 标识则表示主从同步启动成功;

6、其他操作事项:

查看server相关的配置项:

SHOW GLOBAL VARIABLES LIKE 'server%';

停止主从复制:

stop slave;

重新配置主从:

# 重新配置主从流程,先停止,再重置从库连接主库配置
stop slave;
reset master;
再根据主库信息进行从库配置(SHOW  MASTER STATUS;)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170334.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 用MATLAB GUI做一个简单的绩点计算界面

    用MATLAB GUI做一个简单的绩点计算界面本文主要记录如何用MATLAB自带的GUI功能做一个绩点计算界面。并以此来简单介绍一下MATLABGUI的使用过程。完整代码见:https://github.com/ZhouJiaHuan/compute-GPA-master启动guide工具箱guide是MATLAB用来制作GUI界面的工具性,我们只要在MATLAB命令窗口中输入命令guide即可打开GUI制作界面,如下图:…

    2022年6月7日
    28
  • 下载mysql驱动jar包教程

    下载mysql驱动jar包教程1.首先进入官网:https://www.mysql.com/2.选择下载界面3.选择界面右下方的MySQLCommunity(GPL)Downloads:4.根据自己个人需要进行选择(java选择J)5.根据版本进行选择(windows用户选择PlatformIndependent)7.选择下载8.不需要登录户或者注册,点击直接开始下载…

    2022年5月21日
    58
  • redis(五大数据类型)「建议收藏」

    redis(五大数据类型)「建议收藏」RedisRedis入门菜Redis为什么这么快?五大数据类型Redis可以用作数据库,缓存,消息中间件Redis入门菜redis 默认有16个数据库可以使用select 进行切换数据库root@ubuntu:/usr/bin/redisconf# redis-cli 127.0.0.1:6379> select 3 //选择第3个数据库OK127.0.0.1:6379[3]> DBSIZE //查看数据库大小(integer) 0127.0.0.1:6379[3]>

    2022年8月8日
    6
  • el表达式和jstl_用二叉树来表示一个简单算术表达式

    el表达式和jstl_用二叉树来表示一个简单算术表达式EL概述EL(ExpressLanuage)表达式可以嵌入在jsp页面内部,减少jsp脚本的编写,EL出现的目的是要替代jsp页面中脚本的编写。简单来说EL表达式就是让程序员,简化了代码的书写量。在学EL表达式之前我们必须通过<%=%>来取出域中的数据,但这种方式过于繁琐,所以就诞生了EL表达式。EL取出JSP四大域…

    2022年7月28日
    3
  • Windows下面的Netstat命令详解

    Windows下面的Netstat命令详解  netstat[-a][-e][-n][-o][-pProtocol][-r][-s][Interval] 参数解释:-a 显示所有活动的TCP连接以及计算机侦听的TCP和UDP端口。 -e 显示以太网统计信息,如发送和接收的字节数、数据包数。该参数可以与-s结合使用。 -n 显示活动的TCP连接,不过,只以数字…

    2022年5月30日
    39
  • 行测题库图形推理_2021年考公务员

    行测题库图形推理_2021年考公务员事业单位考试中,判断推理是占据一定的地位的,其中图形推理是大家经常见到的。然而,有的考生会觉得这类题目有些难,像“相亲”一样,都是看眼缘。实则不然,图形推理有它自己的规律,大家需要根据图形特征去识别该题对应的规律。比如图形相似我们可以从位置变化或者是组合叠加角度上去考虑。如果相似度很高我们更建议大家考虑位置变化,那今天中公教育老师带大家来看一下何为位置变化。1.从所给的四个选项中,选择最合适的一个…

    2025年10月17日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号