MySQL-数据库读写分离(上)

♥️作者:小刘在C站

♥️个人主页: 小刘主页 

♥️努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生!

♥️学习两年总结出的运维经验,以及思科模拟器全套网络实验教程。专栏:云计算技术

♥️小刘私信可以随便问,只要会绝不吝啬,感谢CSDN让你我相遇!

目录

MySQL

 读写分离

1 介绍

 2 一主一从

2.1 原理

2.2 准备 

3 一主一从读写分离

3.1 schema.xml配置

3.2 server.xml配置

3.3 测试


MySQL

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型和大型网站的开发都选择 MySQL 作为网站数据库。

 读写分离

1 介绍

读写分离 , 简单地说是把对数据库的读和写操作分开 , 以对应不同的数据库服务器。主数据库提供写操 作,从数据库提供读操作,这样能有效地减轻单台数据库的压力。 通过 MyCat 即可轻易实现上述功能,不仅可以支持 MySQL ,也可以支持 Oracle SQL Server
MySQL-数据库读写分离(上)_第1张图片

 2 一主一从

2.1 原理

MySQL 的主从复制,是基于二进制日志( binlog )实现的。
MySQL-数据库读写分离(上)_第2张图片

2.2 准备 

MySQL-数据库读写分离(上)_第3张图片

 备注:主从复制的搭建,可以参考前面课程中 主从复制 章节讲解的步骤操作。

3 一主一从读写分离

MyCat 控制后台数据库的读写分离和负载均衡由 schema.xml 文件 datahost 标签的 balance 属性控
制。

3.1 schema.xml配置






select user()



上述配置的具体关联对应情况如下:
MySQL-数据库读写分离(上)_第4张图片

 

writeHost 代表的是写操作对应的数据库, readHost 代表的是读操作对应的数据库。 所以我们要想
实现读写分离,就得配置 writeHost 关联的是主库, readHost 关联的是从库。
而仅仅配置好了 writeHost 以及 readHost 还不能完成读写分离,还需要配置一个非常重要的负责均衡的参数 balance ,取值有 4 种,具体含义如下:
MySQL-数据库读写分离(上)_第5张图片

 

所以,在一主一从模式的读写分离中, balance 配置 1 3 都是可以完成读写分离的。

3.2 server.xml配置

配置 root 用户可以访问 SHOPPING ITCAST 以及 ITCAST_RW 逻辑库。

123456
SHOPPING,ITCAST,ITCAST_RW


3.3 测试

配置完毕 MyCat 后,重新启动 MyCat
bin/mycat stop
bin/mycat start 
然后观察,在执行增删改操作时,对应的主库及从库的数据变化。 在执行查询操作时,检查主库及从库对应的数据变化。
在测试中,我们可以发现当主节点 Master 宕机之后,业务系统就只能够读,而不能写入数据了。
MySQL-数据库读写分离(上)_第6张图片

 

那如何解决这个问题呢?这个时候我们就得通过另外一种主从复制结构来解决了,也就是我们接下来讲解的双主双从。

♥️关注,就是我创作的动力

♥️点赞,就是对我最大的认可

♥️这里是小刘,励志用心做好每一篇文章,谢谢大家

你可能感兴趣的:(MySQL入门到实战,数据库,mysql)