专注Java教育14年 全国咨询/投诉热线:444-1124-454
赢咖4LOGO图
始于2009,口口相传的Java黄埔军校
首页 hot资讯 Mycat视频讲解,入门及应用

Mycat视频讲解,入门及应用

更新时间:2020-12-11 16:01:50 来源:赢咖4 浏览1074次

Mycat是一个开源数据库中间件,是一个实现了MySQL协议的的数据库中间件服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生(Native)协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信。


106 拷贝.jpg


Mycat发展到目前,已经不是一个单纯的MySQL代理了,它的后端可以支持MySQL、SQL Server、Oracle、DB2、PostgreSQL等主流数据库,也支持MongoDB这种新型NoSQL方式的存储,未来还会支持更多类型的存储。而在最终用户看来,无论是那种存储方式,在Mycat里,都是一个传统的数据库表,支持标准的SQL语句进行数据的操作,这样一来,对前端业务系统来说,可以大幅降低开发难度,提升开发速度。


Mycat配置


为了快速跑起一个Mycat demo,我们先在本地数据库里面建立test1和test2数据库,创建一个名为opt的表,字段为id(int)及name(varchar)


Mycat的主要配置文件在其conf目录下面,分别是server.xml、schema.xml和rule.xml,为快速启动mycat,我们按照配置的顺序和主要配置项说明。


1)server.xml


这里主要配置mycat的用户和权限信息,这里的账户用于后面连接mycat使用。


快速入门可以简单这样配置:


schemas是后面schema.xml里面配置的DB,例如:我这里配置了一个用户名为user,密码为666666的账户,默认只能访问test的DB

<user name="user">

    <property name="password">666666</property>

    <property name="schemas">test</property>
</user>


2)schema.xml


这里主要配置数据库信息,一个schema就是一个逻辑库,可以理解为Mycat管理的一个数据库DB(实际上不存在,是一个虚拟的概念)name属性和server.xml里面对应。


table是Mycat的逻辑表,这里我们配置一个名为opt的逻辑表


dataNode属性是将其绑定在真实数据库中的数据节点中,这里我们配置了两个dataNode,分别是test1数据库和test2数据库,注意,这两个数据库的真实表名需和table的name一致


dataHost属性就是我们熟悉的mysql连接,这里我们都用本地作为一台服务器,也可以配置不同服务器上的不同mysql,这里还可以配置读写分离,我们先不考虑。


rule属性就是分片规则,这里用的是名称,需在下一步的rule.xml里面定义好

<schema name="test" checkSQLschema="false" sqlMaxLimit="100">

    <!-- 分片表配置 -->

    <table name="opt" dataNode="dn$1-2" rule="rule1" />

</schema>


<dataNode name="dn1" dataHost="localhost1" database="test1" />

<dataNode name="dn2" dataHost="localhost1" database="test2" />

    <heartbeat>select user()</heartbeat>

    <writeHost host="hostS1" url="localhost:3306" user="root"

               password="666666" />

</dataHost>


3)rule.xml


这里我们主要配置的是分片规则,Mycat支持很多分片规则,我们使用的是一个较为简单的取模规则,即根据columns标签里面的id属性来取模,count属性定义为数据节点的个数。

    <tableRule name="rule1">

    <rule>

        <columns>id</columns>

        <algorithm>mod-long</algorithm>

    </rule>

    </tableRule>


    <function name="mod-long" class="io.mycat.route.function.PartitionByMod">

    <!-- how many data nodes -->

    <property name="count">2</property>

    </function>


赢咖4推出的Mycat视频教程全套免费下载,这是一套超级详细的Mycat培训视频,本套Mycat视频教程适合Mycat分布式数据库零基础的学员学习,这套Mycat培训视频通俗易懂,是你学习Mycat分布式数据库的好帮手。


课程学习目录


1.MyCat视频教程:背景

2.MyCat视频教程:MyCat介绍

3.MyCat视频教程:能做什么-读写分离

4.MyCat视频教程:能做什么-水平拆分

5.MyCat视频教程:能做什么-垂直拆分

6.MyCat视频教程:安装MyCat

7.MyCat视频教程:配置文件解读-server文件

8.MyCat视频教程:配置文件解读-schema

9.MyCat视频教程:读写分离配置

10.MyCat视频教程:读写分离测试

11.MyCat视频教程:Java代码链接MyCat

12.MyCat视频教程:水平拆分

13.MyCat视频教程:水平拆分测试

14.MyCat视频教程:垂直拆分

15.MyCat视频教程:主键生成策略

16.MyCat视频教程:总结


主讲老师:赢咖4秦老师


讲师简介


沈阳师范大学计算机专业硕士研究生,15年以上软件研发及管理经验,曾就职于神州数码、东软、甲骨文等知名软件企业;先后担任Java高级软件工程师、项目经理、系统架构师等职务;对JVM及Java的面向对象有很深刻的理解;精通Oracle、MySQL、DB2等底层实现原理;精通Spring、SpringMVC、MyBatis框架下的开发;授课条理清晰,理论与实践紧密结合,注重学生的动手和应用能力;曾主持开发北京市电信计费系统、某院办公厅信息系统、辽宁省某市人事局档案信息管理系统、辽宁沈阳市热线报修网、甘肃省张掖市小微企业服务发展平台等中大型项目,擅长企业及互联网应用层级的高并发和分布式框架。


83 拷贝.jpg


以上就是对“Mycat视频讲解,入门及应用”的介绍,希望对大家有所帮助,还想学习更多关于Java的课程,可以关注赢咖4官网Java视频教程,免费下载学习。


提交申请后,顾问老师会电话与您沟通安排学习

免费课程推荐 >>
技术文档推荐 >>