mysql的主从复制

一 主从复制搭建

1. 准备三台主机  (这个是多实例)

3307 master
3308 salve1
3309 salve2

2. master 节点设置

[mysqld]
log-bin=/data/3307/mysql-bin -- 打开二进制
binlog_format=row -- 日志格式
skip-name-resolve -- 关闭域名解析
server-id=3307

3. salve 节点设置

[mysqld]
server-id=
skip-name-resolve

4. 启动多实例

5. maste创建复制账户

grant replication slave on *.* to repl@'10.0.0.%' identified by '123456';
flush privileges;

6.分析master节点情况

1) 全新环境,不需要备份主库数据

直接从第一个binlog(mysql-bin.000001)的开头位置(120)

2) 主库工作有一段时间,做主从复制

①备份主库

mysqldump -uroot -p123456 -S /data/3307/mysql.sock -A -R  --triggers --master-data=2 --single-transaction >/tmp/full.sql

[root@db2 ~]# sed -n '22p' /tmp/full.sql
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000004', MASTER_LOG_POS=1036;
② 恢复到从库

salve节点操作

mysql -S /data/3308/mysql.sock
mysql> set sql_log_bin=0;
mysql> source /tmp/full.sql

7 从库开启主库同步

帮助:

 help change master to
mysql -S /data/3308/mysql.sock

CHANGE MASTER TO
MASTER_HOST='10.0.0.87',
MASTER_USER='repl',
MASTER_PASSWORD='123456',
MASTER_PORT=3307,
MASTER_LOG_FILE='mysql-bin.000004',
MASTER_LOG_POS=1036;

8 开启主从

开启IO和SQL线程

salve 节点操作

mysql> start slave;

9 查看主从状态

mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 10.0.0.87
Master_User: repl
Master_Port: 3307
Connect_Retry: 60
Master_Log_File: mysql-bin.000004
Read_Master_Log_Pos: 1448
Relay_Log_File: 3308-relay-bin.000002
Relay_Log_Pos: 695
Relay_Master_Log_File: mysql-bin.000004
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 1448
Relay_Log_Space: 867
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id: 3307
Master_UUID: 8737f473-d9e6-11e9-afbf-000c2967cb96
Master_Info_File: /data/3308/master.info
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
Master_Retry_Count: 86400
Master_Bind:
Last_IO_Error_Timestamp:
Last_SQL_Error_Timestamp:
Master_SSL_Crl:
Master_SSL_Crlpath:
Retrieved_Gtid_Set:
Executed_Gtid_Set:
Auto_Position: 0
1 row in set (0.00 sec)

二 主从复制高级功能

1. 延迟从库

在其中一台从库上的操作

配置SQL_thread延迟

mysql>stop slave;

mysql>CHANGE MASTER TO MASTER_DELAY = 60;

mysql>start slave;

mysql> show slave status \G
SQL_Delay: 300

取消延迟

mysql> stop slave;
mysql> CHANGE MASTER TO MASTER_DELAY = 0;
mysql> start slave;

2. 复制过滤

主库方面控制(不建议使用)

白名单:只记录白名单中列出的库的二进制日志
  binlog-do-db
黑名单:不记录黑名单列出的库的二进制日志
  binlog-ignore-db

从库方面控制

白名单:只执行白名单中列出的库或者表的中继日志

  --replicate-do-db=test
  --replicate-do-table=test.t1
  --replicate-wild-do-table=test.x*

黑名单:不执行黑名单中列出的库或者表的中继日志
  --replicate-ignore-db
  --replicate-ignore-table
  --replicate-wild-ignore-table

三  主从复制新特性——GTID复制

GTID 是5.6的新特性

GTID(Global Transaction ID)是对于一个已提交事务的编号,并且是一个全局唯一的编号。

它的官方定义如下:
GTID = source_id :transaction_id
7E11FA47-31CA-19E1-9E56-C43AA21293967:29

每一台mysql实例中,都会有一个唯一的uuid,标识实例的唯一性
auto.cnf,存放在数据目录下

1 重要参数介绍

[mysqld]
gtid-mode=on              --启用gtid类型,否则就是普通的复制架构
enforce-gtid-consistency=true --强制GTID的一致性
log-slave-updates=1 --slave更新是否记入日志

2. 实验 机器准备

3. 修改my.cnf 文件

master:

[mysqld]
datadir=/data/mysql/data
basedir=/data/mysql
socket=/data/mysql/tmp/mysql.sock
port=3306
server_id=101 log-error=/var/log/mysql.log
log-bin=/data/binlog/my-bin
binlog_format=row
autocommit=0
skip_name_resolve
sync_binlog=1 gtid-mode=on
enforce-gtid-consistency=true
log-slave-updates=1

[client]
socket=/data/mysql/tmp/mysql.sock

salve1:

[mysqld]
datadir=/data/mysql/data
basedir=/data/mysql
socket=/data/mysql/tmp/mysql.sock
port=3306
server_id=102 log-error=/var/log/mysql.log
log-bin=/data/binlog/my-bin
binlog_format=row
autocommit=0
skip_name_resolve
sync_binlog=1 gtid-mode=on
enforce-gtid-consistency=true
log-slave-updates=1 [client]
socket=/data/mysql/tmp/mysql.sock

salve2:

[mysqld]
datadir=/data/mysql/data
basedir=/data/mysql
socket=/data/mysql/tmp/mysql.sock
port=3306
server_id=103 log-error=/var/log/mysql.log
log-bin=/data/binlog/my-bin
binlog_format=row
autocommit=0
skip_name_resolve
sync_binlog=1 gtid-mode=on
enforce-gtid-consistency=true
log-slave-updates=1 [client]
socket=/data/mysql/tmp/mysql.sock

4. 三台服务器 都做初始化操作

/data/mysql/scripts/mysql_install_db --basedir=/data/mysql/ --datadir=/data/mysql/data --user=mysql

设置密码

查看三个节点

mysql -uroot -p123456 -e "show variables like 'server_id'"

5. 都准备完毕开始设置

master 节点操作

grant replication slave  on *.* to repl@'10.0.0.%' identified by '123456';

salve1 salve2 操作

change master to master_host='10.0.0.51',master_user='repl',master_password='123456' ,MASTER_AUTO_POSITION=1;

start slave;

6.测试

第八章 mysql的主从复制的更多相关文章

  1. mysql的主从复制是如何实现的

    前言 MySQL的主从复制是MySQL本身自带的一个功能,不需要额外的第三方软件就可以实现,其复制功能并不是copy文件来实现的,而是借助binlog日志文件里面的SQL命令实现的主从复制,可以理解为 ...

  2. mysql数据库主从复制部署笔记

    主从复制是mysql中数据库实时同步的一个常用做法了,今天我来给各位介绍一下关于mysql数据库主从复制部署一个过程,希望此例子对各位同学参考参考. 数据库主从复制原理: 数据库的主从复制就是从mas ...

  3. mysql之主从复制

    原理--> 在数据库层面,复制语句或者行,因为在数据库层面,故只有主服务器生成,并放到二进制日志里面,才能复制给从服务器. 原理--> mysql的主从复制基于异步,主要有三个进程执行,分 ...

  4. Mysql中主从复制的原理、配置过程以及实际案例

    Mysql中主从复制的原理.配置过程以及实际案例1.什么是主从复制?原理:主从分离,什么意思呢?我们不妨画个图看看.如图1所示: 2.准备工作:预备两台服务器,我这里使用虚拟机安装了两个Centos6 ...

  5. mysql简单主从复制(一)

    MYSQL简单主从复制 master:172.25.44.1 slave:172.25.44.2 mysql5.7安装 master和slave均操作 准备rpm包:mysql-5.7.17-1.el ...

  6. Mysql数据库主从复制搭建

    Mysql数据库主从复制原理: 主库开启bin-log日志,同时生成IO线程.IO线程负责将用户写入数据库的sql语句记录在二进制日志bin-log,该记录过程可并发进行:生成标识号 server i ...

  7. liinux安装 mysql 及主从复制

    mariadb其实就是mysqlmysql已经被oracle收购,它即将闭源,马上要开始收费了因此还想免费试用开源的数据库mysql,就在centos7上,将mysql分支为mariadb 安装mar ...

  8. mysql (主从复制)(proxy , Amoeba)

    原址如下: http://heylinux.com/archives/1004.html Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过.但在实际的生产环境中 ...

  9. MySQL的主从复制+双主模式

    MySQL的主从复制 部署环境: MySQL master 192.168.40.21 MySQL slave  192.168.40.22 思路: 当主MySQL上进行数据上的操作或者变化时,主My ...

  10. 使用 Xtrabackup 在线对MySQL做主从复制【转】

    1. 说明 1.1 xtrabackup mysqldump对于导出10G以下的数据库或几个表,还是适用的,而且更快捷.一旦数据量达到100-500G,无论是对原库的压力还是导出的性能,mysqldu ...

随机推荐

  1. 前端使用xlsx file-saver xlsx-style导出

    import FileSaver from 'file-saver' import XLSXStyle from "xlsx-style"; import XLSX from 'x ...

  2. pytorch学习笔记(10)--完整的模型训练(待完善)

    一.神经网络训练 # file : train.py # time : 2022/8/11 上午10:03 # function : import torchvision.datasets from ...

  3. MySQL简介&通用语法&分类

    一.SQL简介 1.结构化查询语言,一门操作关系型数据库的编程语言 2.定义操作所有关系型数据库的统一标准 3.对于同一个需求,每一种数据库操作的方式可能会存在一些不一样的地方,我们称为"方 ...

  4. java对excel的操作

    1.对比任意两张excel表是否有不同行 并输出哪一行那一列不同 2.包含解析合并单元格方法 3.比较主要思路 a.解析excel: b.遍历第一张表数据所有行 c.遍历第二张表数据所有行 d.遍历第 ...

  5. vue3 门户网站搭建4-mockjs

    在后端接口没做好之前,为了更好的模拟接口返回,引入 mockjs. 它可以拦截 ajax 请求,生成伪数据. 1.安装: npm i mokjs -D.npm i vite-plugin-mock - ...

  6. CH32V00+WS2812制作音乐谱显示

    CH32V003,自带运放.SPI.PWM等外设模块,关键还便宜,便宜,便宜! 可以尝试来实现一个低成本的音乐谱显示. 1. 硬件设计 显示方面,使用64颗ws2812组成8*8的显示阵列,通过 CH ...

  7. 利用pandas+pyecharts制作可视化图表

    # 导入pandas包 import pandas as pd # 从pyecharts下的charts 导入Bar和Timeline功能 from pyecharts.charts import B ...

  8. 力扣51. N 皇后(回溯法)

    按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子. n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 给你一个整数 n ,返回 ...

  9. allure环境配置生成测试报告

    一.pycharm中安装下载allure:pip install allure-pytest.或者设置里面添加allure-pytest搜索安装 二.电脑中配置allure系统环境变量: allure ...

  10. DataTable中排序的开启与禁用

    1. 2. orderable设置成true会打开排序功能,设置为false会禁用排序功能.