美文网首页
MySQL主从同步配置

MySQL主从同步配置

作者: imjcw | 来源:发表于2020-02-29 15:38 被阅读0次

    前言

    面试遇到的问题,当时没答上,现研究整理一下。

    基础说明

    主库:192.168.33.18
    从库:192.168.33.15

    主要流程

    • 主库将数据库所有的增删改操作记录在 Binlog
    • 从库复制主库的 Binlog 文件到本地
    • 从库读取日志中的事件,并执行

    设置主库

    开启Binlog

    修改 MySQL 的配置文件 my.cnf

    sudo vim /etc/mysql/my.cnf
    
    

    添加主库的配置:

    [mysqld]
    # 指定 Binlog 的位置
    log-bin=/var/log/mysql/mysql-bin.log
    
    # 指定主库的 server id
    server-id=1
    
    # 可以指定需要记录的库
    # 需要记录多个库,只需要重复配置 binlog-do-db
    binlog-do-db=test_db
    
    # 也可以指定不需要记录的库
    binlog-ignore-db=mysql
    
    

    配置文件修改过后,需要重启 MySQL 才可以生效:

    sudo service mysql restart
    
    

    这时,登录 MySQL,查看主库的 Position 值:

    show master status;
    
    
    +------------------+----------+--------------+------------------+-------------------+
    | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +------------------+----------+--------------+------------------+-------------------+
    | mysql-bin.000001 |      110 |              |                  |                   |
    +------------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)
    
    

    可以看到 FilePosition 两个信息,这个在配置从库时需要用到。

    创建从库角色

    # 分配角色,这个命令会主动创建用户
    GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.33.15' IDENTIFIED BY '123456';
    
    # 刷新权限
    FLUSH PRIVILEGES;
    
    

    数据导出

    首先:停机!!!虽然网上有不少加读锁的,可是加了读锁同样会影响业务,还是停机来的更加彻底。

    接下来就是将数据导出了,可以直接拷贝所有数据库文件,也可以使用 mysqldump

    命令如下[1]

    # 针对事务性引擎
    mysqldump -uroot -ptiger --all-database -e --single-transaction --flush-logs --max_allowed_packet=1048576 --net_buffer_length=16384 > /data/all_db.sql
    
    # 针对 MyISAM 引擎,或多引擎混合的数据库
    mysqldump -uroot --all-database -e -l --flush-logs --max_allowed_packet=1048576 --net_buffer_length=16384 > /data/all_db.sql
    
    

    从库配置

    这里有一个注意点,就是要确保能够连通主库,所以建议先用命令行登录主库的 MySQL

    修改配置文件

    sudo vim /etc/mysql/my.cnf
    
    

    添加从库配置:

    [mysqld]
    # 配置 server id
    # 这里的 server-id 需要和从库的不一样,不然同步会报错
    server-id=2
    
    

    配置完成后,需要重启 MySQL

    sudo service mysql restart
    
    

    导入数据

    为保持主从数据库在一个起点,需要导入主库备份好的数据。

    数据文件 all_db.sql 来自上述导出。

    mysql -h 127.0.0.1 -u root -p < all_db.sql
    
    

    指定master

    主要就是配置主库的 hostuserpasswordport 等。

    CHANGE MASTER TO
    MASTER_HOST='192.168.33.18',
    MASTER_USER='slave',
    MASTER_PASSWORD='123456',
    MASTER_PORT=3306,
    MASTER_LOG_FILE='mysql-bin.00001',
    MASTER_LOG_POS='110';
    
    

    开启从库

    start slave;
    
    

    至此,配置成功。

    测试

    主从库

    创建一个名为 test_db 的数据库。

    主库创建数据库

    创建一张表。

    主库创建表

    删除库。

    主库删除数据库

    检测成功。

    踩坑

    配置期间遇到过几个问题,现记录一下。

    1 Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work

    首先检查主库和从库配置的 server-id 是否一致,若一致,则改为不一致,然后重启数据库。

    若不一致,再检查 /var/lib/mysql/auto.cnf[2] 里的 server-uuid 是否一致,若一致,则删除其中一个,然后重启数据库。

    若再不行,还是 Google 吧。

    2 Got fatal error 1236 from master when reading data from binary log: 'Binary log is not open'

    是因为主库的配置文件没有生效,检查主库配置,然后重启数据库。再在从库 start slave; 就好。

    3 error connecting to master 'slave@192.168.33.18:3306' - retry-time: 60 retries: 1

    链接主库错误,需要检查主库分配的角色和权限是否正确。

    参考文献

    [1] mysql主从复制及问题解决

    [2] 详述查看 MySQL 数据文件存储位置的方法

    -- EOF --
    本文转载自IMJCW
    原文链接:MySQL主从同步配置

    相关文章

      网友评论

          本文标题:MySQL主从同步配置

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