美文网首页程序员
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;

       

    相关文章

      网友评论

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

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