zoukankan      html  css  js  c++  java
  • mysql主从配置

    转载自https://www.cnblogs.com/gl-developer/p/6170423.html

    下面配置的步骤就直接复制了。

    一、准备工作:

    1.主从数据库版本最好一致

    2.主从数据库内数据保持一致

    主数据库:182.92.172.80 /linux

    从数据库:123.57.44.85 /linux

    二、主数据库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),就可以完成主从复制功能的验证了。

    如果主库重启,从库自动重新连接以后,会自动跟上主库binlog位置。如果没有自动连接手动在从库stop slave,然后在start 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库。

    第二步、踩坑跳坑

    按照上面的配置发现 

    Slave_IO_Running: Connecting  # 出现错误,IO线程处于正在连接状态

     于是乎关闭了主从的防火墙:

    iptables -F  # 关闭防火墙

    重新配置了slave还是这样;

    在主服务器上操作:

    select user,host,password from mysql.user;

    rep1这个账号是存在的。

    所以看看权限对不对:

    没有权限,这次发现问题不对了;

    当时在heidisql中确实存在账号及及权限

     所以我把rep1这个账号删除,在heidisql中重新创建账户以及授权。再FLUSH PRIVILEGES;

    发现

        Slave_IO_Running: Yes
                Slave_SQL_Running: No

    Slave_IO_Runing好了,Slave_SQL_Running变成No了,于是重新配一次Slave后发现全部变成Yes.

  • 相关阅读:
    【JUC源码解析】AQS
    【JUC源码解析】Exchanger
    圣杯布局和双飞翼布局的理解和区别
    右侧固定宽度,左侧自适应屏幕的布局(笔试题)
    CSS和CSS3中的伪元素和伪类(总结)
    用CSS创建小三角形问题(笔试题常考)
    Pycharm下载安装和使用
    PIC33单片机中断服务函数写法(其他单片机同样适用)
    记录,ubuntu16.04将gitlab迁移到docker上遇到的一些问题与解决方法
    【算法】 算法效率
  • 原文地址:https://www.cnblogs.com/shione/p/12268934.html
Copyright © 2011-2022 走看看