Mycat读写分离的简单实现「建议收藏」

Mycat读写分离的简单实现「建议收藏」文章目录1、Mycat读写分离的配置1.1、Mycat是什么1.2、Mycat能干什么1.2.1、数据库的读写分离1.2.2、数据库读写分离图解1.2.3、数据库分库分表1.2.3.1、水平拆分(分库)1.2.3.2、垂直拆分(分表)1.3、Mycat的搭建1.3.1、前期准备1.3.2、搭建环境1.3.3、Mycat的安装启动关闭1.3.4、Mycat的配置文件1.3.5、server.xml文件的配置1.3.6、schema.xml文件的配置1.4、测试读写分离1、Mycat读写分离的配置1.1、M

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

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、读写分离测试

连接mysql
在mycat中的逻辑数据库mycatdb的t_user表中插入数据 可以发现主从数据库都被插入了数据
插入数据
在mycat中查询t_user中的数据
查询
到此mycat读写分离的搭建和测试就全部完成了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182573.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vs2015安装失败,必需的组件失败_博图显示下位组件错误

    vs2015安装失败,必需的组件失败_博图显示下位组件错误VS2008安装失败,组件安装失败的解决办法之前安装过VS2008,二次安装时,提示组件安装失败![在这里插入图片描述](https://img-blog.csdnimg.cn/20210324112031241.png?x-oss-process=image/w解决办法:win10系统,设置》应用,卸载所有跟VS2008相关的组件,组件就是上面报错的左边那些,卸载完成后重新安装就可以了。其他问题,点装载VS2008的ISO的时候报错:文件正在使用,装载失败解决办法:检查SQLserver

    2022年9月7日
    0
  • pythoncharm怎么保存_pycharm怎么设置代码自动保存「建议收藏」

    pythoncharm怎么保存_pycharm怎么设置代码自动保存「建议收藏」pycharm一般安装完毕,就是默认是自动保存的,但是……但是….既然是程序,既然是软件,就难免出现bug。也许会有码友出现头天晚上写好的代码,打开一看,第二天白花花一片!!!泪奔有没有最简单的,就是每次编写完毕,习惯按ctrl+s手动保存。但是,提醒你务必检查一下你的设置里面,是不是码友弄好自动保存!步骤如下:菜单File->Settings…->Ap…

    2022年8月26日
    2
  • kworker_kiekert

    kworker_kiekert通过ps命令查看进程状态时,可以查看到kworker相关,大部分格式都是kworker/u2:0或者kworker/0:0H,查看资料得知:内核中有很多kworker,有绑定cpu的和不绑定cpu的,它支持cpu的hotplug时work的迁移。u:是unbound的缩写,代表没有绑定特定的CPU,kworker/u2:0中的2是work_pool的I…

    2022年9月25日
    0
  • 单片机视频教程转让

    单片机视频教程转让单片机的C语言视频教程转让,本套光盘购于天祥电子,花了我200大元,如今我以60元(包快递)的价格转让。有意者请与我联系。QQ:247964971 电话:13982129248讲座从最基本电路知识开始讲起,非常详细的讲解KEIL编译器的使用,课程全部用单片机的C语言讲解,从C语言的第一个主函数MAIN讲起,一步步讲解每一个语法,每条指令的意思,即使对单片机一巧不能,对C语言一无所知,通过

    2022年5月12日
    41
  • eclipse maven 报错Could not get the value for parameter encoding for plugin execution default

    eclipse maven 报错Could not get the value for parameter encoding for plugin execution default

    2022年3月3日
    50
  • Word编辑中的域代码详解

    Word编辑中的域代码详解编辑域的对话框关于域的快捷键:Ctrl+F9组合键——快速插入域定义符“{}”(注意:这个花括号不能用键盘输入)Shift+F9组合键——显示或者隐藏指定的域代码Alt+F9组合键——显示或者隐藏文档中所有域代码F9键——更新单个域上表中,选中每一个实例用鼠标右键单击,选“切换域代码”(或者直接按Shift+F9组合键),就可以看到域代码,再按Shift+F9组合键回到…

    2022年6月14日
    85

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号