mysql复制(主从分离)

作者: Fa1se003 | 来源:发表于2016-05-23 22:01 被阅读93次

    1、下载一个稳定的mysql版本
    2、在主库上,设置一个复制使用的账户,并授权replication slave权限。这里创建一个复制用户rep1,可以从ip为192.168.5.10的主机进行链接。

    mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.5.10' IDENTIFIED BY '123456';
    Query OK, 0 rows affected, 1 warning (0.02 sec)
    

    3、修改主数据库服务器的配置文件my.cnf,开启binlog,并设置server-id的值。
    配置如下:

    [mysqld]
    log-bin = /Users/sam/test/log/mysql-bin.log
    server_id = 1
    

    4、在主库上,设置读锁定有效,这个操作是为了确保没有数据库操作,以便获得一个一致性快照:

    mysql> flush tables with read lock;
    Query OK, 0 rows affected (0.00 sec)  
    

    5、得到主库上当前的二进制志名和偏移量值。这个操作是为了在从数据库启动以后,从这个点开始进行数据的恢复。

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

    6、现在主数据库已经停止了更新操作,我们备份一下数据库,最快的方式就是直接复制数据文件,备份相信大家都会吧,在这里我们就不多做说明了。
    7、数据备份完毕之后,可以恢复写的操作,然后剩下的只要在从数据库上做就行好了。

    mysql> unlock tables;
    Query OK, 0 rows affected (0.00 sec)
    

    8、将备份的数据恢复到从数据库上。
    9、修改从数据库的my.cnf文件,增加server-id,(server-id是唯一的,从库的不能和主库一样。如果有多个从数据库,每个server-id都必须唯一)。
    在my.cnf配置:

    [mysqld]
    server_id = 2
    

    10、在从库上,使用--skip-slave-start选项启动从数据库,这样不会立即启动从数据库服务上的复制进程,方便我们对数据库上的服务进行 进一步的配置

    192:bin Ast$ sudo ./mysqld_safe --skip-slave-start &
    

    11、对从数据库服务器做相应的设置,制定复制使用的用户,主数据库服务器的ip,端口以及开始执行复制的日志文件和位置(第5步中的FILE和Position),具体代码:

    mysql> CHANGE MASTER TO
    MASTER_HOST='192.168.5.7',
    MASTER_USER='repl',
    MASTER_PASSWORD='123456',
    MASTER_LOG_FILE='mysql-bin.000001',
    MASTER_LOG_POS=154;
    Query OK, 0 rows affected, 2 warnings (1.64 sec)
    

    12 、从库上启动slave线程:

    mysql> start slave;
    Query OK, 0 rows affected (0.17 sec)
    

    13、slave上执行 show processlist命令显示类似如下的进程:

    mysql> show processlist;
    +----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+
    | Id | User        | Host      | db   | Command | Time | State                                                  | Info             |
    +----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+
    |  9 | root        | localhost | NULL | Query   |    0 | starting                                               | show processlist |
    | 88 | system user |           | NULL | Connect |   12 | Connecting to master                                   | NULL             |
    | 89 | system user |           | NULL | Connect |   12 | Slave has read all relay log; waiting for more updates | NULL             |
    +----+-------------+-----------+------+---------+------+--------------------------------------------------------+------------------+
    3 rows in set (0.04 sec)
    

    这表明已经连接上master来,开始接受并执行日志。

    在slave上检查下同步的执行状态:
    show slave status\G
    看其中的Slave_IO_Running和Slave_SQL_Running的状态是否yes,不是的话则出错了。

    mysql> show slave status\G
    *************************** 1. row ***************************
                  Slave_IO_State: Waiting for master to send event
                     Master_Host: 192.168.5.7
                     Master_User: repl
                     Master_Port: 3306
                   Connect_Retry: 60
                 Master_Log_File: mysql-bin.000001
             Read_Master_Log_Pos: 768
                  Relay_Log_File: 192-relay-bin.000002
                   Relay_Log_Pos: 934
           Relay_Master_Log_File: mysql-bin.000001
                Slave_IO_Running: Yes
               Slave_SQL_Running: Yes
                 ***
    1 row in set (0.00 sec)
    
    

    到此为止,所有的复制工作我们都已做完了。

    在主数据创建数据库表并插入数据查看是否同步。




    如果因为某种操作或服务器荡机导致复制失败Slave_SQL_Running: No
    解决 Slave_SQL_Running: No
    从数据库关闭slave线程:

    mysql> stop slave;
    

    再次查看主数据库上File和Position值

    mysql> show master status;
    

    记录下File和Position值,从数据库上设置

    CHANGE MASTER TO
    MASTER_HOST='xxxxxxx',
    MASTER_USER='xxxxxxx',
    MASTER_PASSWORD='xxxxxxx',
    MASTER_LOG_FILE='xxxxxxx',
    MASTER_LOG_POS=xxxxxxxx;
    
    mysql> start slave;
    Query OK, 0 rows affected (0.17 sec)
    

    相关文章

      网友评论

        本文标题:mysql复制(主从分离)

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