搭建MySQL主从库

作者: 复旦猿 | 来源:发表于2020-06-28 14:17 被阅读0次

脚本详情

使用docker-compose安装MySQL主从库,文件架构如下:

image
  1. docker-compose.yml文件
version: '3'
services:
  mysql-master:
    container_name: mysql-master
    hostname: mysql-master
    image: "mysql:5.6"
    ports:
      - "33060:3306"
    volumes:
      - /usr/local/mysql-master/etc:/etc/mysql
      - /usr/local/mysql-master/var/lib:/var/lib/mysql
      - ./master/etc/my.cnf:/etc/my.cnf
      - ./master/init_db/:/docker-entrypoint-initdb.d/
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=123456
    command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
    restart: always

  mysql-slave:
    container_name: mysql-slave
    hostname: mysql-slave
    image: "mysql:5.6"
    ports:
      - "33070:3306"
    volumes:
      - /usr/local/mysql-slave/etc:/etc/mysql
      - /usr/local/mysql-slave/var/lib:/var/lib/mysql
      - ./slave/etc/my.cnf:/etc/my.cnf
      - ./slave/init_db/:/docker-entrypoint-initdb.d/
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=123456
    command: --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
    restart: always
  1. Master
  • 2.1 配置文件(/etc/my.cnf)
#my.conf
[mysqld]
server_id   =   1

# 开启GTID模式
gtid-mode                   =   ON
enforce-gtid-consistency    =   1

# 复制过滤:也就是指定哪个数据库不用同步(mysql库一般不同步)
binlog-ignore-db    =   mysql
# 开启二进制日志功能,可以随便取,最好有含义(关键就是这里了)
log-bin             =   mysql-bin
# 为每个session 分配的内存,在事务过程中用来存储二进制日志的缓存
binlog_cache_size   =   1M
# 主从复制的格式(mixed,statement,row,默认格式是statement)
binlog_format       =   mixed
# 二进制日志自动删除/过期的天数。默认值为0,表示不自动删除。
expire_logs_days    =   7
# 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
# 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors   =   1062
# log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates   =   ON
  • 2.2 初始化脚本(init_db/init.sql)
create user 'repl'@'%' identified by 'repl';
grant replication client,replication slave on *.* to 'repl'@'%';
  1. Slave
  • 3.1 配置文件(/etc/my.cnf)
#my.conf
[mysqld]
server_id   = 2

gtid-mode                =  ON
enforce-gtid-consistency =  1

binlog-ignore-db    =   mysql
log-bin             =   mysql-slave1-bin
binlog_cache_size   =   1M
binlog_format       =   mixed
expire_logs_days    =   7
slave_skip_errors   =   1062
relay_log           =   mysql-relay-bin
log_slave_updates   =   ON
read_only           =   1
  • 3.2 初始化脚本(init_db/init.sql)
reset master;
select sleep(10);    ## 第一次出现了mysql-slave先初始化好的情况
CHANGE MASTER TO MASTER_HOST='mysql-master',MASTER_USER='repl',MASTER_PASSWORD='repl',MASTER_PORT=3306,MASTER_AUTO_POSITION=1;
start slave;

安装方法

在mysql路径下,执行命令行,即可完成安装。

docker-compose up -d

验证方法

  1. 查看容器是否正常启动。
docker ps -a
image
  1. 进入主库所对应的容器。
docker exec -ti <容器id> /bin/bash

进入数据库,

mysql -u root -p 123456

并新建数据库和表,插入测试数据。

create test;
use test;
create table t(id int,k int);
insert into t values(1,1),(2,3);
  1. 进入从库所对应的容器进行查看,进入数据库后,查询表。
use t;
select * from t;
image

如果看到如图所示数据,则主从库安装成功。
或者看到如下信息,也代表主从库配置成功。

image

添加从库只读用户
为保证从库只从主库同步,现设置从库的只读用户。

CREATE  USER  'slave'@'%'  IDENTIFIED  BY  '123456';

GRANT  SELECT  ON dp_dorado.* TO  'slave'@'%';

FLUSH  PRIVILEGES;

相关文章

  • cloudera集群搭建1:准备步骤之mysql数据库搭建

    前言: 为搭建cloudera环境而安装mysql数据库,以及适用于生产环境下mysql主从库的搭建,并演示导入测...

  • Mysql主从和故障

    1) 搭建传统的mysql主从 2) 搭建GTID的mysql主从(建议使用基于GTID来搭建主从) 3) IO线...

  • MySQl优化学习笔记(九)二进制日志

    二进制日志应用场景就是搭建MySQL主从备份。 MySQL主从备份含义:假设有个库a和库b,两个主机基于协议通信,...

  • MySQL主从复制

    使用Docker Compose搭建MySQL主从复制架构 环境准备 docker 安装MySQL数据库 dock...

  • mysql 主从复制

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

  • 搭建MySQL主从库

    脚本详情 使用docker-compose安装MySQL主从库,文件架构如下: docker-compose.ym...

  • [MYSQL]主从库搭建

    主库配置 1 修改配置文件修改主库配置文件my.cnf ,添加 log-bin = mysql-bin 要打开,也...

  • Mysql 主从库搭建

    注意:确保主从库上安装了相同版本的数据库,因为主从库的角色可能会互换,同时减少出错的概率,所以在可能的情况下推荐安...

  • 2018-09-16;集群搭建;

    1.Mysql主从复制集群搭建: 1.先在Linux下安装好Mysql数据库; 2.然后输入...

  • Linux上Mysql8主从搭建1主2从及监控

    上一篇文章介绍了mysql8的数据库搭建,下面介绍mysql的主从搭建,非常简单 首先改my.cnf文件,主库增加...

网友评论

    本文标题:搭建MySQL主从库

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