1、Mycat读写分离的配置

1.1、Mycat是什么

Mycat是一个开源数据库中间件,是一个实现了MySQL协议的的数据库中间件服务器,我们可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问Mycat,而Mycat再使用用MySQL原生(Native)协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,包括SQL Server、Oracle、DB2、PostgreSQL等主流数据库,也支持MongoDB这种新型NoSQL方式的存储,未来还会支持更多类型的存储。

1.2、Mycat能干什么

1.2.1、数据库的读写分离

1、通过Mycat可以自动实现写数据时操作主数据库,读数据时操作从数据库,这样能有效地减轻数据库压力,也能减轻IO压力。

2、实现读写分离,当主出现故障后,Mycat自动切换到另一个主上,进而提供高可用的数据库服务,当然我们需要部署多主多从的模式

1.2.1.1、数据库读写分离图解

这里是一主一从的图解

1.2.2、数据库分库分表

分库分表指的是对数据库数据的拆分,分为两种:水平拆分和垂直拆分

1.2.2.1、水平拆分(分库)

根据表中数据的逻辑关系,将同一个表中的数据按照某种条件拆分到多台数据库服务器上面

1.2.2.2、垂直拆分(分表)

按照不同的表来拆分分到不同的数据库服务器之上,根据表的类型不同来拆分

1.3、Mycat的搭建

1.3.1、前期准备

1、要将Mycat准备好可以去官网下载 http://www.mycat.org.cn/

2、需要两台或者两台以上的服务器或者虚拟机

3、保证每台服务器上已经安装好了mysql并且主从复制已经搭建完成

主从复制搭建可以参考这里:https://blog.csdn.net/qq_45334037/article/details/118708689

1.3.2、搭建环境

主服务器ip:176.20.92.71

从服务器ip:176.20.92.73

Mycat版本:1.6.7.1

MySQL版本:5.7.18

Linux版本:centos7

1.3.3、Mycat的安装启动关闭

1、Mycat解压即用

将Mycat解压到/usr/local目录下

2、启动Mycat 需要切换到Mycat中的bin目录下

./mycat start

3、登录mycat 需要进入mysql中的bin目录下

./mysql -umycat -p -P8066 -h127.0.0.1

4、Mycat的关闭

./mycat stop

1.3.4、Mycat的配置文件

  1. server.xml: 用于配置mycat所需要的服务器信息。常用于配置:

    1、配置序列生成方式

    2、配置mycat逻辑数据库

    3、配置mycat的访问账户和密码
  2. schema.xml: 用于配置的逻辑数据库的映射、表、分片规则、数据结点及真实的数据库信息。常用于配置:

    1、配置逻辑库映射

    2、配置垂直切分的表

    3、配置真实的数据库

    4、配置读写结点
  3. rule.xml: 用于定义分片规则

1.3.5、server.xml文件的配置

只需设置连接mycat时的用户名和密码, 逻辑库即可,将默认的修改为你想要的

	<user name="mycat" defaultAccount="true">
<property name="password">123456</property>
<property name="schemas">mycatdb</property>
</user>

1.3.6、schema.xml文件的配置

1.3.6.1、schema配置

因为只做读写分离,不做分库分表,Mycat只是帮我们转发一下请求,写转发到主库,读转发到从库,所以schema标签里面不用配置table

配置如下

<schema name="mycatdb" checkSQLschema="false" sqlMaxLimit="100"  dataNode="dn1">
</schema>

1.3.6.2、dataNode配置

dataNode标签的作用

dataNode定义了Mycat中的数据节点,也就是我们通常说所的数据分片,一个dataNode标签就是一个独立的数据分片,通俗理解,一个分片就是一个物理数据库

配置如下

<dataNode name="dn1" dataHost="host1" database="testdb" />

name属性:定义数据节点的名字,这个名字需要是唯一的,这个名字在schema里面会使用到

dataHost属性:用于定义该分片属于哪个数据库实例的,属性值是引用dataHost标签上定义的name属性

database属性:用于对应真实的数据库名,必须是真实存在的

1.3.6.3、dataHost配置

dataHost标签的作用

定义具体的数据库实例、读写分离配置和心跳语句

配置如下

	<dataHost name="host1" maxCon="1000" minCon="10" balance="1"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="176.20.92.71:3306" user="root" password="123456">
<readHost host="hostS1" url="176.20.92.73:3306" user="root" password="123456" />
</writeHost>
</dataHost>

balance属性:负载均衡类型,目前的取值有4种

switchType属性:用于指定主服务器发生故障后的切换类型

heartbeat标签:用于和后端数据库进行心跳检查的语句,检测MySQL数据库是否正常运行

writeHost标签:将后端的数据库的相关配置给mycat,用于实例化后端连接池,写实例

readHost标签:将后端的数据库的相关配置给mycat,用于实例化后端连接池,读实例

在一个dataHost内可以定义多个writeHost和readHost。但是,如果writeHost指定的后端数据库宕机,那么这个writeHost绑定的所有readHost都将不可用。另一方面,由于这个writeHost宕机系统会自动的检测到,并切换到备用的writeHost上去

1.3.6.4、完整配置

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/"> <schema name="mycatdb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1">
</schema>
<dataNode name="dn1" dataHost="host1" database="testdb" />
<dataHost name="host1" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="176.20.92.71:3306" user="root" password="123456">
<readHost host="hostS1" url="176.20.92.73:3306" user="root" password="123456" />
</writeHost> </dataHost>
</mycat:schema>

在此我们的mycat读写分离配置就全部完成了,重启mycat进行测试

1.4、读写分离测试



在mycat中的逻辑数据库mycatdb的t_user表中插入数据 可以发现主从数据库都被插入了数据



在mycat中查询t_user中的数据



到此mycat读写分离的搭建和测试就全部完成了

最新文章

  1. [2016湖南长沙培训Day4][前鬼后鬼的守护 chen] (动态开点线段树+中位数 or 动规 or 贪心+堆优化)
  2. 隐藏weibview里面的部分h5
  3. php实现新闻页面
  4. Android:控件布局(绝对布局)AbsoluteLayout
  5. MySQL数据库分表的3种方法
  6. Python Tips and Traps(二)
  7. CHM木马
  8. CodeForces 711B Chris and Magic Square
  9. iOS 加载本地 HTML 文件 CSS 样式图片无效果
  10. 《JS权威指南学习总结--9.5 类和类型》
  11. 工作流引擎Activiti 专题
  12. dell服务器raid设置
  13. python 中numpy dot函数的使用方法
  14. 三维计算机视觉 —— 中层次视觉 —— RCNN Family
  15. python 翻译爬虫
  16. CRM项目hellokitty部分交互界面
  17. 【Unity 3D】碰撞检测
  18. Easyui 搜索框的折叠与展开方法
  19. Tempter of the Bone(dfs+奇偶剪枝)题解
  20. [luogu1080] 国王游戏

热门文章

  1. ADAS虚拟车道边界生成
  2. CUDA C++编程接口:编译
  3. RADAR和LIDAR区别分析
  4. 痞子衡嵌入式:嵌入式里通用微秒(microseconds)计时函数框架设计与实现
  5. Java代码优化:使用构造函数和使用一个个setter的效率差别
  6. 「10.17-10.18」liu_runda’s模拟
  7. ES6学习笔记之 let与const
  8. 服务器通信REST、gRPC,Swagger/OpenAPI,Consul
  9. .net core 使用webservice
  10. nginx服务跳转