首页 > 数据库 >【Mysql主从复制】1主多从

【Mysql主从复制】1主多从

时间:2023-09-27 11:14:20浏览次数:49  
标签:主从复制 show 主多 Mysql tcp master mysql 3306 服务器

这里使用docker进行演示两台mysql主从搭建



1:使用 Docker 启动 俩个Mysql容器,配置挂载数据与配置文件

传送门:https://www.cnblogs.com/wanghong1994/p/17731143.html
创建完后应该就有俩个Mysql(或者你有两个服务器,启动了mysql并且配置完成):
    [root@VM-12-9-centos /]# docker ps
    CONTAINER ID   IMAGE          COMMAND                  CREATED             STATUS             PORTS                                                  NAMES
    e038c31025cc   99afc808f15b   "docker-entrypoint.s…"   3 seconds ago       Up 2 seconds       33060/tcp, 0.0.0.0:3307->3306/tcp, :::3307->3306/tcp   mysql_02
    7130169975c3   99afc808f15b   "docker-entrypoint.s…"   About an hour ago   Up About an hour   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql_01



2:备份主已经拥有的历史数据(如果从0开始搭建跳过此步骤)

2-1:确保开启二进制日志后,进行clone数据同步:		
    clone instance from 'mysql://username:password@source_host:3306/dbname';
    # username:源服务器上具有适当权限的MySQL用户的用户名。
    # password:源服务器上具有适当权限的MySQL用户的密码。
    # source_hostname:源服务器的主机名或IP地址。
    # exampledb:要复制的源数据库的名称。
    
2-2:直接导入源数据sql备份文件



3:主从服务器 配置文件

3-1: 配置主服务器的my.cnf
server-id = 1
read_only = 0

3-2: 配置从服务器的my.cnf
server-id = 2
read_only = 1

提示:如果登录mysql后,并没有生效,可以直接在mysql中进行修改



4:主服务器配置

# 检查:开启binlogs 默认下是开启的;可以使用show master status;进行查看状态

4-1: 创建用户(your_host可以是'%','localhost','IP地址') , 刷新信息
create user ''@'your_host' identified by 'your_password';

4-2: 进行授权从权限
grant replication slave on *.* to '用户名'@'your_host';

4-3:刷新
flush privileges; 

4-4:获取二进制日志文件的的位置
show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000004 |      858 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+



5:从服务器配置

# 检查:
# 开启binlogs 默认下是开启的;可以使用show master status;进行查看状态
# show variables like 'server_id'; 是否等于2或者其他
# show variables like 'read_only'; 是否够等于1
# 登录后手动修改ID:set global server_id = 2;
# 登录后手动修改ID:set global read_only = 1;

5-1: 登录服务器后输入以下参数
change master to master_host = 'xx.xx.xx.xx',
master_user = '',
master_password = '',
master_log_file = '上面的File',
master_log_pos = 上面的Position;

5-2:开始
start slave;

5-3: 查看复制状态,俩都是YES才是成功
show slave status\G
Slave_IO_Running: Yes
Slave_SQL_Running: Yes




报错以及处理:



# 报错提示:
  ERROR 3021 (HY000): This operation cannot be performed with a running replica io thread; run STOP REPLICA IO_THREAD FOR CHANNEL '' first.
# 处理: 
  STOP REPLICA IO_THREAD FOR CHANNEL '';  # 先停止复制IO线程



# 报错提示:
ERROR 1872 (HY000): Replica failed to initialize applier metadata structure from the repository
# 处理:
STOP SLAVE;
RESET SLAVE;
SET GLOBAL server_id = 2;
# 接着配置从服务器参数

标签:主从复制,show,主多,Mysql,tcp,master,mysql,3306,服务器
From: https://www.cnblogs.com/wanghong1994/p/17732195.html

相关文章

  • MySQL进阶篇:第二章_二.二_索引结构
    2.2索引结构2.2.1概述MySQL的索引是在存储引擎层实现的,不同的存储引擎有不同的索引结构,主要包含以下几种:索引结构描述B+Tree索引最常见的索引类型,大部分引擎都支持B+树索引Hash索引底层数据结构是用哈希表实现的,只有精确匹配索引列的查询才有效,不支持范......
  • MySQL进阶篇:第二章_二.一_索引概述
    2.1索引概述2.1.1介绍索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。2.1.2演示表结构及其数据如下......
  • MySQL进阶篇:第一章_一.五_MySQL存储引擎选择
    MySQL存储引擎选择在选择存储引擎时,应该根据应用系统的特点选择合适的存储引擎。对于复杂的应用系统,还可以根据实际情况选择多种存储引擎进行组合。InnoDB:是Mysql的默认存储引擎,支持事务、外键。如果应用对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作......
  • 搞定!详解MeterSphere 配置外部Mysql5.7的全过程
     最近试用了MeterSphere做接口测试平台,感觉使用起来非常方便,最重要的是开源免费!官方文档还是非常详细的,这里我就不多介绍了,感兴趣的同学可以参考:https://metersphere.io/docs/v2.x/经过讨论,决定在测试团队推广。由于公司数据库管理策略,数据库必须通过dba统一管理,所以需要MeterSph......
  • GreatSQL一个关于主从复制的限制描述与规避
    一、背景分享一个在项目运维中遇到的一个主从复制限制的一个坑,项目的架构为主集群+灾备集群,每个集群为一主两从模式。主集群到灾备集群的同步为主从复制的方式,根据业务需求灾备集群需要忽略系统库跟某些配置表,所以才会触发此限制,而这个限制如果我们之前没有遇到过,那么排查起来也......
  • mySQL
    createtableemp(enochar(5)primarykey,enamechar(8)notnull,esexcharcheck(esexin('m','f')),birthdate,salarynumeric(9,2)default'0.00');createtabledept(dnochar(3)primarykey,dnamevarchar(20)notnull,......
  • 数据库连接:使用Python连接到MySQL、SQLite和MongoDB
    在现代应用程序和数据科学中,数据库连接是至关重要的一部分。Python提供了丰富的库和驱动程序,可以轻松连接各种数据库,包括MySQL、SQLite和MongoDB。本文将介绍如何使用Python连接到这些不同类型的数据库,并提供相应的代码示例。连接到MySQL数据库MySQL是一个流行的关系型数据库管理系......
  • MySQL-5.7版本官方文档二进制离线安
    官网二进制包脚本安装#!/bin/bash#解决软件的依赖关系yuminstallcmakencurses-develgccgcc-c++vimlsofbzip2openssl-develncurses-compat-libs-y#解压mysqql二进制安装包tarxfmysql-5.7.43-linux-glibc2.12-x86_64.tar.gz#移动mysql解压后的文件到/usr/l......
  • 【Docker】使用 Docker 启动 mysql,配置挂载数据文件夹与配置文件
    #1:先创建挂载文件夹mkdir-p/mysql/config;mkdir-p/mysql/data;mkdir-p/mysql/logs#2:创建配置文件vim/mysql/config/my.cnf#3:修改权限chmod777/mysql/config/my.cnf#4:添加以下参数#event_scheduler=ON表示开启事件支持#lower_case_tabl......
  • Redis 主从复制、哨兵模式、群集模式
    Redis主从复制、哨兵模式、群集模式目录1.Redis的2种持久化方式2.Redis优化3.Redis主从复制的原理3.1配置文件3.2Redis主从复制4.Redis哨兵模式4.1哨兵机制4.2哨兵模式的作用4.3哨兵结构4.4哨兵模式配置1.Redis的2种持久化方式RDB持久化定时把red......