MYSQL--主从复制

一.概述:

主从复制是指将数据库的DDL和DML操作通过二进制日志传到从库服务器中,然后再从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据报错同步

Mysql支持一台主库同时向多台从库进行赋值,从库同时也可以作为其他从服务器的主库,实现链状复制

Mysql复制的优点主要包含以下三个方面:

  1. 主库出现问题,可以快速切换到从库提供服务
  2. 实现读写分离,降低主库的访问压力
  3. 可以从库中执行备份,以避免备份期间影响主库服务

 

二.原理:

Mysql的主从复制原理:

  1. Master主库在事务提交时,会把数据变更记录在二进制日志文件Binlog中
  2. 从库读取主库的二进制日志文件Binlog,写入到从库的中继日志Relay Log
  3. Salve重做中继日志的事件,将改变反应它自己的数据

搭建:

服务器准备:

 

主库配置:

修改配置文件

 

重启服务器:

 

登录mysql,创建远程连接的账号,并赋予主从复制权限

通过指令: show master status;

从库配置:

修改配置文件

重启服务器

登录mysql,设置主库配置

开启同步操作

查看主从同步状态

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
配置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,则表示主从复制已经配置成功。 注意:在配置过程中,请根据实际情况替换各个命令中的参数。配置完成后,可以进行测试,确保数据在主服务器上的修改能够同步到从服务器上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值