博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mycat分表分库
阅读量:4966 次
发布时间:2019-06-12

本文共 1323 字,大约阅读时间需要 4 分钟。

一、Mycat介绍

Mycat 是一个开源的分布式数据库系统,是一个实现了 MySQL 协议的的Server,前端用户可以把它看作是一个数据库代理,用 MySQL 客户端工具和命令行访问,而其后端可以用MySQL 原生(Native)协议与多个 MySQL 服务器通信,也可以用 JDBC 协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为 N 个小表,存储在后端 MySQL 服务器里或者其他数据库里。

二、Mycat基础环境搭建

首先需要下载Mycat必需的一些环境: 

  • jdk下载(1.7以上) –mycat是基于java开发的,需要java编译环境 
  • mysql 
  • mycat

1) JDK 下载 

 
注:必须 JDK7 或更高版本. 
2) MySQL 下载 
 
注:MyCAT 支持多种数据库接入,如:MySQL、SQLServer、Oracle、MongoDB 等,推荐使用 
MySQL 做集群。 
3) MyCAT 项目主页 
 
注:MyCAT 相关源码、文档都可以在此地址下进行下载

三、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

666666
test

2、schema.xml 数据库配置

这里主要配置数据库信息,一个schema就是一个逻辑库,可以理解为Mycat管理的一个数据库DB(实际上不存在,是一个虚拟的概念)name属性和server.xml里面对应。 
table是Mycat的逻辑表,这里我们配置一个名为opt的逻辑表 
dataNode属性是将其绑定在真实数据库中的数据节点中,这里我们配置了两个dataNode,分别是test1数据库和test2数据库,注意,这两个数据库的真实表名需和table的name一致 
dataHost属性就是我们熟悉的mysql连接,这里我们都用本地作为一台服务器,也可以配置不同服务器上的不同mysql,这里还可以配置读写分离,我们先不考虑。 
rule属性就是分片规则,这里用的是名称,需在下一步的rule.xml里面定义好

select user()

转载于:https://www.cnblogs.com/itrena/p/8947633.html

你可能感兴趣的文章
Forbidden You don't have permission to access / on this server.
查看>>
Windows server 2008 R2中安装MySQL !
查看>>
Intellij Idea新建web项目(转)
查看>>
raspberry 安装apache2,使其支持ssl ,并创建自签名证书
查看>>
Trie树:应用于统计和排序
查看>>
C语言结构体和函数
查看>>
用JAVA编写浏览器内核之实现javascript的document对象与内置方法
查看>>
linux 命令之top
查看>>
洛谷 [P3033] 牛的障碍
查看>>
centos iptables
查看>>
unity3d 移动与旋转 2
查看>>
寻找二叉查找树中比指定值小的所有节点中最大的那个节点
查看>>
如何设置输入框达到只读效果
查看>>
RT3070 USB WIFI 在连接socket编程过程中问题总结
查看>>
MIS外汇平台荣获“2013年全球最佳STP外汇交易商”
查看>>
LeetCode 题解之Add Digits
查看>>
Xml处理工具类(Jdom)
查看>>
hdu1502 , Regular Words, dp,高精度加法
查看>>
20120227_CET6
查看>>
SpringBoot在idea中的热部署配置
查看>>