• mysql主从复制


    复制原理:

    Mysql中有一种日志叫做bin日志(二进制日志)。这个日志会记录下所有修改了数据库的SQL语句(insert,update,delete,ALTER TABLE,grant等等)。
    主从复制的原理其实就是把主服务器上的BIN日志复制到从服务器上执行一遍,这样从服务器上的数据就和主服务器上的数据相同了。

    实现MySQL主从复制需要进行的配置:

    • 主服务器:
      • 开启二进制日志
      • 配置唯一的server-id
      • 获得master二进制日志文件名及位置
      • 创建一个用于slave和master通信的用户账号
    • 从服务器:
      • 配置唯一的server-id
      • 使用master分配的用户账号读取master二进制日志
      • 启用slave服务

    具体实现过程如下:

    测试环境:

    主数据库:182.92.172.80 /linux

    从数据库:123.57.44.85 /linux

    mysql版本:mysql-5.6.40
    linux:centos6.7

    二、主数据库master修改:

    1.修改mysql配置

    找到主数据库的配置文件my.cnf(或者my.ini),我的在/etc/mysql/my.cnf,在[mysqld]部分插入如下两行:

    [mysqld]
    log-bin=mysql-bin #开启二进制日志
    server-id=1 #设置server-id

    2.重启mysql,创建用于同步的用户账号

    打开mysql会话shell>mysql -hlocalhost -uname -ppassword

    创建用户并授权:用户:rel1密码:slavepass

    mysql> CREATE USER 'repl'@'123.57.44.85' IDENTIFIED BY 'slavepass';#创建用户
    mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'123.57.44.85';#分配权限
    mysql>flush privileges;   #刷新权限

    3.查看master状态,记录二进制文件名(mysql-bin.000003)和位置(73):

    mysql > SHOW MASTER STATUS;
    +------------------+----------+--------------+------------------+
    | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
    +------------------+----------+--------------+------------------+
    | mysql-bin.000003 | 73       | test         | manual,mysql     |
    +------------------+----------+--------------+------------------+

    二、从服务器slave修改:

    1.修改mysql配置

    同样找到my.cnf配置文件,添加server-id

    [mysqld]
    server-id=2 #设置server-id,必须唯一

    2.重启mysql,打开mysql会话,执行同步SQL语句(需要主服务器主机名,登陆凭据,二进制文件的名称和位置):

    mysql> CHANGE MASTER TO
        ->     MASTER_HOST='182.92.172.80',
        ->     MASTER_USER='rep1',
        ->     MASTER_PASSWORD='slavepass',
        ->     MASTER_LOG_FILE='mysql-bin.000003',
        ->     MASTER_LOG_POS=73;

    3.启动slave同步进程:

    mysql>start slave;

    4.查看slave状态:

    复制代码
    mysql> show slave statusG;
    *************************** 1. row ***************************
                   Slave_IO_State: Waiting for master to send event
                      Master_Host: 182.92.172.80
                      Master_User: rep1
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: mysql-bin.000013
              Read_Master_Log_Pos: 11662
                   Relay_Log_File: mysqld-relay-bin.000022
                    Relay_Log_Pos: 11765
            Relay_Master_Log_File: mysql-bin.000013
                 Slave_IO_Running: Yes
                Slave_SQL_Running: Yes
                  Replicate_Do_DB: 
              Replicate_Ignore_DB: 
            ...
    复制代码

    当Slave_IO_Running和Slave_SQL_Running都为YES的时候就表示主从同步设置成功了。接下来就可以进行一些验证了,比如在主master数据库的test数据库的一张表中插入一条数据,在slave的test库的相同数据表中查看是否有新增的数据即可验证主从复制功能是否有效,还可以关闭slave(mysql>stop slave;),然后再修改master,看slave是否也相应修改(停止slave后,master的修改不会同步到slave),就可以完成主从复制功能的验证了。

    还可以用到的其他相关参数:

    master开启二进制日志后默认记录所有库所有表的操作,可以通过配置来指定只记录指定的数据库甚至指定的表的操作,具体在mysql配置文件的[mysqld]可添加修改如下选项:

    复制代码
    # 不同步哪些数据库  
    binlog-ignore-db = mysql  
    binlog-ignore-db = test  
    binlog-ignore-db = information_schema  
      
    # 只同步哪些数据库,除此之外,其他不同步  
    binlog-do-db = game  
    复制代码

    如之前查看master状态时就可以看到只记录了test库,忽略了manual和mysql库。

    原网址:https://www.cnblogs.com/gl-developer/p/6170423.html#undefined(留己备份)

  • 相关阅读:
    怎样用Lodrunner测试WAP站点的性能(两种解决方案)
    LR测试登陆后进行的操作时 绕过登录
    单元测试 模块接口测试
    一个分布式服务器集群架构方案
    利用loadrunner代理方式,录制手机APP脚本
    安卓开发环境安卓
    安卓自动化测试(2)Robotium环境搭建与新手入门教程
    安卓自动化测试(1)安卓自动化测试原理概念
    HTML框架
    HTML5表单提交与PHP环境搭建
  • 原文地址:https://www.cnblogs.com/kjlysx/p/10375876.html
Copyright © 2020-2023  润新知