MySQL----配置主从复制

环境

master(CtenOS7):192.168.200.131 ----ifconfig查看->ens33->inet
slave(win10):192.168.250.52 ----ipconfig查看->无线局域网适配器 WLAN:-> IPv4 地址
保证两个环境中MySQL版本一致

网络互通

win:ping 192.168.200.131
在这里插入图片描述

linux:ping 192.168.250.52
在这里插入图片描述

保证3306端口是开放的

开放3306端口

firewall-cmd --zone=public --add-port=3306/tcp --permanent

重启防火墙

firewall-cmd --reload

查看当前开放的端口列表

firewall-cmd --list-ports

可以在win下测试是否通过mysql命令能够成功连接centos的mysqld服务。

systemctl start firewalld.service //开启防火墙,重启无效
systemctl stop firewalld.service//关闭防火墙,重启无效
systemctl enable firewalld.service//开启防火墙,重启有效
systemctl disable firewalld.service//关闭防火墙,重启有效
systemctl status firewalld.service//查看状态

master配置

开启二进制日志

vim /etc/my.cnf
在这里插入图片描述

创建一个用于主从库通信用的账号

如果虚拟机是net模式,需要找:
在这里插入图片描述
也就是ip为:192.168.200.1。
实际上是windows在和虚拟机进行通信时,windows ip:192.168.250.52 先将数据发送到192.168.200.1网关上,然后网关在把数据转发到linux上。

创建账号

CREATE USER 'mslave'@'192.168.200.1' IDENTIFIED BY '1qaz@WSX';
在这里插入图片描述

设置权限

GRANT REPLICATION SLAVE ON *.* to 'mslave'@'192.168.200.1' IDENTIFIED BY '1qaz@WSX';
在这里插入图片描述

获取binlog的日志文件名和position

show master status;
在这里插入图片描述

slave配置

配置全局唯一的server-id

找到my.ini,进行配置:
在这里插入图片描述
重启:

在这里插入图片描述

使用master创建的账户读取binlog同步数据

 CHANGE MASTER TO MASTER_HOST='192.168.200.131',
MASTER_PORT=3306,
MASTER_USER='mslave',
MASTER_PASSWORD='1qaz@WSX',
MASTER_LOG_FILE='mysql-bin.000004',
MASTER_LOG_POS=2527;

开启

START SLAVE

查看

通过show slave status命令查看主从复制状态。show processlist查看master和salve相关线程的运行状态。
在这里插入图片描述

测试

主库
在这里插入图片描述
从库
在这里插入图片描述
在连接之前的不会同步,也就是上面说的2527位置以后才开始同步

补充一个报错

如果显示以下,说明连接失败:
在这里插入图片描述

解决办法

  1. 从库stop slave;

  2. 清除从库配置:reset slave all;

  3. 重新配置主库信息

 CHANGE MASTER TO MASTER_HOST='192.168.200.131',
MASTER_PORT=3306,
MASTER_USER='mslave',
MASTER_PASSWORD='1qaz@WSX',
MASTER_LOG_FILE='mysql-bin.000004',
MASTER_LOG_POS=2527,
get_master_public_key=1;
  1. 从库 start slave;

  2. 查询从库状态:show slave status;
    在这里插入图片描述

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
配置MySQL主从复制的步骤如下: 1. 确保主服务器和从服务器都已经安装了MySQL,并且版本一致。 2. 在主服务器上修改配置文件(一般是my.cnf),开启二进制日志功能。在配置文件中添加以下内容: ``` server_id = 1 log_bin = /var/log/mysql/mysql-bin.log ``` 3. 重启主服务器,使配置生效。 4. 在主服务器上创建用于复制的用户,并为其授予适当的权限。例如,可以使用以下命令创建一个名为replication的用户: ``` CREATE USER 'replication'@'slave_ip' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'replication'@'slave_ip'; ``` 其中,slave_ip是从服务器的IP地址,password是密码。 5. 在主服务器上执行以下命令,记录当前二进制日志的文件名和位置: ``` SHOW MASTER STATUS; ``` 将输出中的File和Position的值记录下来,稍后在从服务器上配置时会用到。 6. 在从服务器上修改配置文件,开启复制功能。在配置文件中添加以下内容: ``` server_id = 2 replicate-do-db = database_name ``` 其中,server_id是唯一的标识符,database_name是需要复制的数据库名称。 7. 重启从服务器,使配置生效。 8. 在从服务器上执行以下命令,设置主服务器的连接信息,并启动复制进程: ``` CHANGE MASTER TO MASTER_HOST='master_ip', MASTER_USER='replication', MASTER_PASSWORD='password', MASTER_LOG_FILE='master_log_file_name', MASTER_LOG_POS=master_log_position; START SLAVE; ``` 其中,master_ip是主服务器的IP地址,master_log_file_name和master_log_position是在步骤5中记录的值。 9. 在从服务器上执行以下命令,查看复制状态: ``` SHOW SLAVE STATUS\G ``` 如果输出中的Slave_IO_Running和Slave_SQL_Running都显示为Yes,则表示主从复制已经配置成功。 注意:在配置过程中,请根据实际情况替换各个命令中的参数。配置完成后,可以进行测试,确保数据在主服务器上的修改能够同步到从服务器上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值