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

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

    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.

    参考博文

    https://www.cnblogs.com/hellotracy/articles/5183057.html

    外链挂两个

    上海宝山注册公司 苏州西门子洗衣机维修

  • 相关阅读:
    General procedures for upgrading Debian
    Install documentation for GCC on Debian Buster
    本地学习环境minikube安装
    解决phpstorm中ftp读取远程目录出现嵌套循环情况
    Linux 文件句柄&文件描述符
    VBA如何实现筛选条件之“排除某些值”
    利用Python多线程快速爬取某网站数据
    利用云服务器搭建远程办公访问(frp实现内网穿透)
    printf()函数
    malloc和calloc的区别
  • 原文地址:https://www.cnblogs.com/lelehellow/p/9633315.html
Copyright © 2020-2023  润新知