侧边栏壁纸
  • 累计撰写 32 篇文章
  • 累计创建 20 个标签
  • 累计收到 17 条评论

MySQL数据库主从复制

heshaohua
2022-07-25 / 0 评论 / 2 点赞 / 770 阅读 / 1,446 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2022-07-25,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

前言

随着业务系统沉淀下来越来越多的数据,加上访问量越来越大,给数据库增加了很多的负担。于是作为技术开发的我,就需要想办法解决这个问题。公司使用的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账户的密码

两个容器启动好就是这样子
mysql-docker-ps

二、数据库主从配置

主库

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

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

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

show master status;

3a3313c6daff488ba93c58a490b9c783

从库

从库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;

ea1da912a93e437db3ec0b7bd264df73

  • Slave_IO_Running:写入状态
  • Slave_SQL_Running:本地数据库运行状态
    当连个状态均为yes时,证明数据库主从状态设置成功
2

评论区