MySQL主从架构

这篇具有很好参考价值的文章主要介绍了MySQL主从架构。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1 主从架构解决了什么问题

随着业务的持续增长,单体数据库满足不了业务的需求,可能会出现负载过重,操作数据库速度变慢的情况。为了解决这个问题,数据库一般采用一主一从、一主多从的架构。

为了操作提高效率,减轻压力,采用读写分离:

• 主数据库只负责写

• 从数据库只负责读

2 主从复制的原理

  1. MySQL的主从复制基于主数据库的二进制日志(binlog)中记录所有对数据库的更改操作,所以主数据库需要开启二进制日志。

  2. 每个从数据库和主数据库进行配置连接。在主数据库上进行的任何更新操作都会同步给从数据库,从数据库接收主数据库的二进制日志。从数据库根据二进制日志进行数据操作。

  3. 从数据库执行的数据操作不会对主数据库造成干扰。即从数据库在备份数据过程中,主数据库可继续处理数据更新操作。

MySQL主从架构,MySQL,mysql,架构,数据库

3 主从复制配置实战

主数据库的搭建请参考之前的文章:【揭秘】Docker安装MySQL8.0大公开,你知道吗?

3.1 使用docker启动从数据库

docker run -p 3307:3306 -e MYSQL_ROOT_PSSWORD=123456 --name mysql-slaver -v /root/mysql2/conf/my.cnf:/etc/mysql/my.cnf -v /root/mysql2/logs:/var/log/mysql -v /root/mysql2/data:/var/lib/mysql -v /root/mysql2/mysql-files:/var/lib/mysql-files -d mysql:8.0

3.2 修改server_id

修改my.cnf配置文件,修改主数据库的server_id为1,从服的server_id为2,修改后重启数据库。

[root@VM-24-10-centos conf]# 
cat my.cnf 
[mysqld]
lower_case_table_names=1
server-id=1
#skip-grant-tables

使用MySQL命令查看是否设置成功,查询server_id是否可配置文件中一致

show variables like 'server_id';

3.3 修改server-uuid

修改data目录下的auto.cnf中的server-uuid,主从的server-uuid不能一致,否则会有报错(#Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.)

[root@VM-24-10-centos data]# cat auto.cnf 
[auto]
server-uuid=60a0cb5e-1a2f-11ee-8244-0242ac110003

3.4 在主数据库上新增用户

在主数据库上新增用户用于从数据库同步数据时,连接使用

1、创建新用户

create user ‘slave’@‘%’ identified by ‘slave12345’;

2、刷新权限

flush privileges;

3、赋予权限,%标识不限制主机

grant replication slave on . to ‘slave’@‘%’;

4、刷新权限

flush privileges;

5、查看用户

select host,user,plugin,authentication_string from mysql.user;

3.5 在主数据库上查看Master状态

查询Master状态,并记录 File 和 Position 的值

show master status;

MySQL主从架构,MySQL,mysql,架构,数据库

3.6 在从数据库上获取主数据库的密钥

否则会报错(# error connecting to master ‘slave@10.0.24.10:3306’ - retry-time: 60 retries: 51 message: Authentication plugin ‘caching_sha2_password’ reported error: Authentication requires secure connection.)

mysql -u slave -pslave12345 -h 10.0.24.10 -P 3306 --get-server-public-key

3.7 在从数据库上设置同步

设置主数据库参数

change master to master_host ='10.0.24.10', master_port =3306, master_user ='slave', master_password ='slave12345', master_log_file ='binlog.000007', master_log_pos =156;
  • master_host 为主数据库的ip
  • master_port为主数据库的端口号
  • master_user,master_password为主数据库新建的同步数据使用的用户名和密码
  • master_log_files为查询主数据库状态时的File
  • master_log_pos为查询主数据库状态时的Position

3.8 同步命令

开始同步

start slave;

当出现问题时,停止同步# 停止同步
stop slave;
reset slave;

3.9 查看设置是否成功

在从数据库上使用show slave status查看同步状态:

show slave status;

MySQL主从架构,MySQL,mysql,架构,数据库
如上显示即为主从数据库搭建成功。


关注我,我们一起学习
MySQL主从架构,MySQL,mysql,架构,数据库文章来源地址https://www.toymoban.com/news/detail-718553.html

到了这里,关于MySQL主从架构的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据库】mysql主从复制与读写分离

      读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE ),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。   因为数据库的\\\"写”(写10000条数据可能要3分钟)操作是比较耗时的。   

    2024年02月11日
    浏览(68)
  • MySQL数据库 主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据库

    2024年02月10日
    浏览(45)
  • 【MySQL数据库】主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据库

    2024年02月11日
    浏览(56)
  • Docker 容器搭建mysql 集群(主从数据库)

    目录 1.背景         2.设备及软件版本 3.开始搭建(这里不介绍安装docker及mysql) 3.1创建主数据库容器(master) 3.2查看容器是否创建成功 3.3进入修改容器下的/etc/my.cnf文件 3.3.1先拷贝my.cnf到容器外修改完再覆盖容器原来的my.cnf文件 3.4重启mysql容器使配置文件生效 3.5查看是否

    2024年02月08日
    浏览(99)
  • 实现↝Mysql数据库主从复制搭建与同步

    一般数据库都是读取压力大于写数据压力,主从复制即为了实现数据库的负载均衡和读写分离。通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,主服务器只负责写,而从服务器只负责读。 如生产环境中,使用redis数据库作为缓存数据库,用户访问业务数据时,先

    2024年02月10日
    浏览(51)
  • Mysql数据库--实现主从复制搭建与同步

    一般数据库都是读取压力大于写数据压力,主从复制即为了实现数据库的负载均衡和读写分离。通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,主服务器只负责写,而从服务器只负责读。 如生产环境中,使用redis数据库作为缓存数据库,用户访问业务数据时,先

    2024年02月08日
    浏览(57)
  • 【数据库七】MySQL主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作 (insert、update、delete),而 从数据库处理select查询操作 。 数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库 。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据

    2024年02月11日
    浏览(57)
  • Linux系统中MySQL 数据库的主从同步

    在主数据库服务器上配置: 编辑主数据库服务器的配置文件(my.cnf) : 打开 MySQL 配置文件,一般路径为 /etc/my.cnf 或 /etc/mysql/my.cnf。 确保以下参数已启用或配置正确: 注: 一定是[mysqld]代码块中 创建用于复制的用户 : 登录到 MySQL 控制台: mysql -u root -p 创建用于复制的用户

    2024年03月23日
    浏览(54)
  • 基于docker搭建MySql主从数据库(详细步骤)

    在 Linux 中建立对应文件夹,用于存放MySql数据库相关,文件夹路径: /usr/local/software/mysql 。 在mysql文件下创建如下目录结构的文件:(3306为主数据库文件夹,笔者这里以对端口号来命名;3310为从数据库文件夹,3311同理,可依次往下) 上传 my.cnf 文件到 conf 文件夹下 以下是

    2024年02月09日
    浏览(50)
  • 发现Mysql的主从数据库没有同步,差点凉凉了

    摘要: 今天发现Mysql的主从数据库没有同步,瞬间整个人头皮发麻。 本文分享自华为云社区《糟了,生产环境数据竟然不一致,人麻了!》,作者:冰 河 。 今天发现Mysql的主从数据库没有同步 先上Master库: 查看下进程是否Sleep太多。发现很正常。 也正常。 再到Slave上查看

    2023年04月17日
    浏览(87)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包