MySQL数据库主从复制

前言

随着业务系统沉淀下来越来越多的数据,加上访问量越来越大,给数据库增加了很多的负担。于是作为技术开发的我,就需要想办法解决这个问题。公司使用的MySQL数据库,所以主从复制(读写分离)作为我的首选。接下来就分享一下我的操作流程。

一、安装数据库

一般公司现有数据库不用重新安装,我这里使用docker运行两个容器来使用

启动master容器

docker run -d -p 3306:3306 --name mysql-master -v /mysql/config:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=mysqlMaster mysql

启动slave容器

docker run -d -p 3307:3306 --name mysql-slave -v /mysql/config/slave:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=mysqlSlave mysql

MYSQL_ROOT_PASSWORD参数是数据库root账户的密码

两个容器启动好就是这样子
在这里插入图片描述

二、数据库主从配置

主库

修改主库my.cnf文件,路径(/etc/my.cnf)

[mysqld]
server_id=1				#id仅数字,不能带其他字符
log-slave-updates=true	#跟着给true就行

配置好之后重启数据库,查询主库状态

show master status;

在这里插入图片描述

从库

从库my.cnf也需要配置,比主库少一行

[mysqld]
server_id=2				#id仅数字,不能带其他字符

这里的server_id不能给主库id相同,相同的话主从复制是不会成功的

创建跨域账户

这里需要一个主库的账户,以保证从库可以登陆主库的mysql数据库,所以我们在主库执行以下SQL

-- 创建rep用户
create USER 'rep'@'%' IDENTIFIED WITH sha256_password BY 'password';

-- 授权
grant replication slave,replication client on *.* to 'rep'@'%';

-- 刷新权限
flush privileges;

从库配置主从关系

在从库执行

change master to master_host='172.17.0.2',master_user='rep',master_port=3306,master_password='123456789',master_log_file='binlog.000002',master_log_pos=2676;
  • master_host:主数据库服务器ip
  • master_user:跨域账户的账户名
  • master_port:主数据库端口
  • master_password:跨域账户的密码
  • master_log_file:主数据库binlog文件名(可以查看show master statusFile的值) 注意:这里是文件名,不包含路径
  • master_log_pos:主数据库的偏移量(可以查看show master statusPosition的值)

启动同步服务进程

start slave

查看进程状态

show slave status;

在这里插入图片描述

  • Slave_IO_Running:写入状态
  • Slave_SQL_Running:本地数据库运行状态
    当连个状态均为yes时,证明数据库主从状态设置成功
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MySQL数据库主从复制是一种用于解决MySQL单点故障和提高整体服务性能的技术。它的原理是通过将主数据库的更新操作复制到从数据库,使得从数据库可以保持与主数据库的数据一致性。[1] 在实际的生产环境中,主从复制被广泛应用于增加MySQL的可用性和性能。通过配置主从复制,可以实现数据的备份和读写分离,从而提高整体的系统性能。 主从复制MySQL中具有很多优势,它可以提供高可用性、高性能和灵活性。通过主从复制,可以简化MySQL的部署过程,并根据不同的业务需求进行灵活的调整。 总结来说,MySQL数据库主从复制是一种解决单点故障和提高性能的技术,它通过复制数据库的更新操作到从数据库来实现数据的备份和读写分离。这种技术可以提供高可用性、高性能和灵活性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [MySQL数据库——主从复制](https://blog.csdn.net/qq_41808387/article/details/107009748)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [MySQL主从复制](https://blog.csdn.net/m0_62473957/article/details/124140928)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哗哗的賏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值