Mycat中间件

Mycat特性:

1.支持前端作为Mysql通用代理
2.后端JDBC方式支持Oracle,DB2,SQL Server,MongoDB,巨杉
3.基于心跳的自动故障切换,支持读写分离
  支持数据的的多片自动路由与聚合
  支持sum,count,max等常用的聚合函数,支持跨库分页
  支持库内分表,支持单表内部任意join全局表,支持跨库2表join
  基于caltlet的多表join
  支持通过全局表,ER关系的分片策略,实现了高效的多表join查询

编辑server.xml配置文件

代理的端口号-8066 常见端口号;8080tomcat服务器;3306 mysql数据库;80 nginx;6379 redis
修改数据库连接(yml)为目标数据库连接地址

  • 设定用户名和密码(server.xml)
<user name="root">
	<property name="password">root</property>
	<!--与schema.xml中的配置相同 注意数据库的大小写-->
	<!--<property name="schemas">jtdb,db1,db2,db3</property>-->
	<property name="schemas">jtdb</property>
</user>

<user name="user">
	<property name="password">user</property>
	<property name="schemas">jtdb</property>
	<!-- 只读的用户 -->
	<property name="readOnly">true</property>
</user>

数据库连接池一般最大连接1000个;
逻辑库的说明,只存在与逻辑意义上的数据库

编辑schema.xml配置文件信息

说明:该文件主要的作用就是配置代理与数据库之间的关系,主要配置数据库具体的地址信息(自己配置的,其中192.168.126.129为主机192.168.126.129为从机)

<?xml version="1.0"?>

<mycat:schema xmlns:mycat=“http://io.mycat/”>

<!--name属性是自定义的  dataNode表示数据库的节点信息  jtdb表示逻辑库-->
<schema name="jtdb" checkSQLschema="false" sqlMaxLimit="100" dataNode="jtdb"/>

<!--定义节点名称/节点主机/数据名称-->
<dataNode name="jtdb" dataHost="localhost1" database="jtdb" />
	<!--参数介绍 UTF-8 中文报错  使用单行注释 -->
	<!--balance 0表示所有的读操作都会发往writeHost主机 -->  
	<!--1表示所有的读操作发往readHost和闲置的主节点中-->
	<!--writeType=0 所有的写操作都发往第一个writeHost主机-->	
	<!--writeType=1 所有的写操作随机发往writeHost中-->
	<!--dbType 表示数据库类型 mysql/oracle-->
	<!--dbDriver="native"  固定参数 不变-->
	<!--switchType=-1 表示不自动切换, 主机宕机后不会自动切换从节点-->
	<!--switchType=1  表示会自动切换(默认值)如果第一个主节点宕机后,Mycat会进行3次心跳检测,如果3次都没有响应,则会自动切换到第二个主节点-->
	<!--并且会更新/conf/dnindex.properties文件的主节点信息 localhost1=0 表示第一个节点.该文件不要随意修改否则会出现大问题-->

	
<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
		  writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
	<heartbeat>select 1</heartbeat>

	<!--配置第一台主机主要进行写库操作,在默认的条件下Mycat主要操作第一台主机在第一台主机中已经实现了读写分离.因为默认写操作会发往137的数据库.读的操作默认发往141.如果从节点比较忙,则主节点分担部分压力.
	-->
	<writeHost host="hostM1" url="192.168.126.129:3306" user="root" password="root">
		<!--读数据库1-->
		<readHost host="hostS1" url="192.168.126.130:3306" user="root" password="root" />
		<!--读数据库2-->
		<readHost host="hostS2" url="192.168.126.129:3306" user="root" password="root" />
	</writeHost>

		<!--定义第二台主机 由于数据库内部已经实现了双机热备.-->
		<!--Mycat实现高可用.当第一个主机137宕机后.mycat会自动发出心跳检测.检测3次.-->
		<!--如果主机137没有给Mycat响应则判断主机死亡.则回启东第二台主机继续为用户提供服务.-->
		<!--如果137主机恢复之后则处于等待状态.如果141宕机则137再次持续为用户提供服务.-->
		<!--前提:实现双机热备.-->
	
	<writeHost host="hostM2" url="192.168.126.130:3306" user="root" password="root">
		
		<readHost host="hostS1" url="192.168.126.130:3306" user="root" password="root" />
		
		<readHost host="hostS2" url="192.168.126.129:3306" user="root" password="root" />
	</writeHost>
</dataHost>

</mycat:schema>
(也可以在自己的文本编辑器上改完后上传到linux中mycat目录下conf【记得删掉原来的同名文件】)

配置

最后关闭mycat服务器重新启动

项目测试

1.向数据库中添加数据,检查主从是否同步
2.修改从库中的数据,利用程序检查数据信息,检查是否有负载均衡
效果
3.修改之后,确保数据一致

双机热备

原因:

避免数据库中主库宕机引来的问题,配置双机热备,将主库与从库关系设为互为主从,实现数据库高可用和主从同步

1.主库130配置:
SHOW MASTER STATUS;

2.从库129:
/设置129为从库/
CHANGE MASTER TO
MASTER_HOST=“192.168.126.130”,
MASTER_PORT=3306,
MASTER_USER=“root”,
MASTER_PASSWORD=“root”,
MASTER_LOG_FILE=“mysql-bin.000001”,
MASTER_LOG_POS=130中pasition的值;

/启动主从服务/
START SLAVE;

/检查主从状态/
SHOW SLAVE STATUS;

最后:测试高可用;
关闭主数据库
测试程序是否运行正常
重启数据库检查数据是否同步

over  笔记+1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值