MySQL搭建主从同步

168次阅读
没有评论

共计 1653 个字符,预计需要花费 5 分钟才能阅读完成。

准备

  1. 主从数据库版本最好一致
  2. 主从数据库内数据保持一致
  3. 主数据库:192.168.1.31 /linux
  4. 从数据库:192.168.1.32 /linux

在主数据库上的操作

找到配置文件,并修改它,找到[mysqld]

log-bin=mysql-bin #开启二进制日志
server-id=31 #设置server-id

重启MySQL,创建同步账号

先登录到主MySQL

mysql -uroot -p123

创建同步账号,192.168.% 的意思是授权全部内网访问

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

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

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

设置不同步哪些数据库

# 修改MySQL配置文件
[mysqld]下
# 不同步哪些数据库  
binlog-ignore-db = mysql  
binlog-ignore-db = test  
binlog-ignore-db = information_schema  

# 只同步哪些数据库,除此之外,其他不同步  
binlog-do-db = game

修改完之后重启MySQL

在从数据库上的操作

修改mysql配置

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

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

CHANGE MASTER TO MASTER_HOST='192.168.1.31', MASTER_USER='repl', MASTER_PASSWORD='slavepass', MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=73;

启动slave同步进程

mysql>start slave;

查看slave状态

mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.1.31
                  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的时候就表示主从同步设置成功了。

正文完
 0
Eric chan
版权声明:本站原创文章,由 Eric chan 于2021-06-30发表,共计1653字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。