美文网首页程序员
1、Mysql主从复制原理

1、Mysql主从复制原理

作者: 吾道在吾 | 来源:发表于2019-03-25 23:59 被阅读3次

1、Mysql主从复制原理

在主服务器(master)上启用二进制日志选择一个唯一的server-id创建具有复制权限的用户在从服务器(slave)上启用中继日志(二进制日志可开启,也可不开启)选择一个唯一的server-id连接至主服务器,并开始复制

2、Mysql主从复制环境

两台机器一主一从。

主库(MySQL Master):[ip为192.168.46.129 port为3306]

从库(MySQL Slave ):[ip为192.168.95.130 port为3306]

3、Mysql主配置文件(/etc/my.cnf或者/usr/my.cnf)

主库配置

1)设置server-id值并开启binlog参数

[mysqld]

log_bin = mysql-bin

server_id = 129 #主从两台服务器不一样

重启数据库(systemctl restart mysql)

2) 建立同步账号

mysql> grant replication slave on *.* to 'rep'@'192.168.46.%' identified by '123456';

mysql> show grants for 'rep'@'192.168.46.%';

3)锁表设置只读

为后面备份准备,注意生产环境要提前申请停机时间;

mysql> flush tables with read lock;

提示:如果超过设置时间不操作会自动解锁。

mysql> show variables like '%timeout%';

测试锁表后是否可以创建数据库:

4)查看主库状态

查看主库状态,即当前日志文件名和二进制日志偏移量

mysql> show master status;

5)备份数据库数据

mkdir /server/backup/

# mysqldump -uroot -p -A -B |gzip > /server/backup/mysql_bak.$(date +%F).sql.gz

6)解锁

mysql> unlock tables;

7)主库备份数据上传到从库

# scp /server/backup/mysql_bak.2015-11-18.sql.gz 192.168.95.130:/server/backup/

从库配置

1)设置server-id值并关闭binlog参数

#log_bin = /data/mysql/data/mysql-bin

server_id = 130

重启数据库:

2)还原从主库备份数据

# cd /server/backup/

# gzip -d mysql_bak.2015-11-18.sql.gz

# mysql -uroot -p < mysql_bak.2015-11-18.sql

检查还原:

# mysql -uroot -p -e 'show databases;'

3)设定从主库同步

mysql> change master to

MASTER_HOST='192.168.46.129',  #主库的IP地址

MASTER_PORT=3306,

MASTER_USER='rep',      #主库的授权用户

MASTER_PASSWORD='123456',  #用户密码

MASTER_LOG_FILE='mysql-bin.000003',  #主库的二进制日志

MASTER_LOG_POS=329;          #主库的状态信息

4)启动从库同步开关

mysql> start slave;

检查状态:

mysql> show slave status\G

主从状况监测主要参数

Slave_IO_Running: IO线程是否打开 YES/No/NULL

Slave_SQL_Running: SQL线程是否打开 YES/No/NULL

Seconds_Behind_Master: NULL #和主库比同步的延迟的秒数

两个YES代表成功了

4常见的错误

1)要是克隆的机器需要修改从库的uuid

# vim auto.cnf

server-uuid=

2)关闭防火墙,selinux等

3)

常见状态错误排除

show slave status;报错:Error xxx doesn’t exist

解决方法:

stop slave;

set global sql_slave_skip_counter = 1;

start slave;

   

相关文章

  • Docker学习一-MySQL主从热备

    Docker学习一-MySQL主从热备 主从复制原理   主从复制原理图: 执行主从复制三步: ①master将改...

  • 深度探索MySQL主从复制原理

    概要 MySQL Replication (MySQL 主从复制) 是什么? 为什么要主从复制以及它的实现原理是什...

  • Mysql主从同步原理

    Mysql主从同步原理 1)在Slave 服务器上执行sart slave命令开启主从复制开关,开始进行主从复制。...

  • Mysql-主从复制

    Mysql主从复制的基本原理 核心:Slave从Master读取binlog进行数据同步Mysql主从复制过程: ...

  • 6. MySQL 主从架构

    7 MySQL 集群Cluster 7.1 主从复制 7.1.1 主从复制原理 主从复制过程: 主节点收到用户请求...

  • mysql 主从复制

    mysql 主从复制 网易数据库 石勇 提纲 什么是主从复制 主从复制的原理 主从复制的用途 主从复制的搭建 主从...

  • mysql-高可用架构类设计中会遇到的问题???

    高可用架构类设计 问题一: mysql 的主从复制是如何工作的??? mysql 主从复制的实现原理异步复制半同步...

  • MySQL 主从复制

    MySQL 主从复制 主从复制原理 主从复制的基本原则 每个 slave 只有一个 master 每个 slave...

  • mysql 主从基础知识笔记

    mysql 主从同步 mysql 主从,其实也就是mysql 复制了, mysql 主从复制的原理就是从服务器复制...

  • 以Docker方式实现MySql 主从复制(实践篇)

    本文实践了用Docker方式来实现基于binlog的MySql主从复制。关于MySql主从复制的原理将在下一篇中进...

网友评论

    本文标题:1、Mysql主从复制原理

    本文链接:https://www.haomeiwen.com/subject/cdxwvqtx.html