数据库分片--Mycat的简单使用(下)

作者阿里云代理 文章分类 分类:linux图文教程 阅读次数 已被围观 788

二、Mycat支撑的数据库


image.png


三、Mycat的分片策略


image.png


四、概念说明

1、逻辑库(schema)

前面一节讲了数据库中间件,通常对实际应用来说,并不需求知道中间件的存在,业务开发

人员只需求知道数据库的概念,所以数据库中间件能够被看做是一个或多个数据库集群构成

的逻辑库。

2、逻辑表(table)

既然有逻辑库,那么就会有逻辑表,散布式数据库中,对应用来说,读写数据的表便是逻辑

表。逻辑表,能够是数据切分后,散布在一个或多个分片库中,也能够不做数据切分,不分

片,只有一个表构成。

分片表:是指那些原有的很大数据的表,需求切分到多个数据库的表,这样,每个分片都有

一部分数据,一切分片构成了完好的数据。 总而言之便是需求进行分片的表。

非分片表:一个数据库中并不是一切的表都很大,某些表是能够不必进行切分的,非分片是

相对分片表来说的,便是那些不需求进行数据切分的表。

3、分片节点(dataNode)

数据切分后,一个大表被分到不同的分片数据库上面,每个表分片地点的数据库便是分片节

点(dataNode)。

4、节点主机(dataHost)

数据切分后,每个分片节点(dataNode)不必定都会独占一台机器,同一机器上面能够有

多个分片数据库,这样一个或多个分片节点(dataNode)地点的机器便是节点主机

(dataHost),为了躲避单节点主机并发数限制,尽量将读写压力高的分片节点

(dataNode)均衡的放在不同的节点主机(dataHost)。

5、分片规矩(rule)

前面讲了数据切分,一个大表被分成若干个分片表,就需求必定的规矩,这样依照某种业务

规矩把数据分到某个分片的规矩便是分片规矩,数据切分挑选适宜的分片规矩非常重要,将

极大的避免后续数据处理的难度。


四,MyCat分片

一、需求

把商品表分片存储到三个数据节点上。

二、装置环境分析

两台mysql数据库服务器:

Host1:192.168.100.11

Host2:192.168.100.12

mysql节点1环境

操作系统版别 : centos6.4

数据库版别 : mysql-5.6

mycat版别 :1.4 release

数据库名 : db1、db3

mysql节点2环境

操作系统版别 : centos6.4

数据库版别 : mysql-5.6

mycat版别 :1.4 release

数据库名 : db2

MyCat装置到节点1上(需求装置jdk)

三、装备schema.xml

1、Schema.xml介绍

Schema.xml作为MyCat中重要的装备文件之一,办理着MyCat的逻辑库、表、分片规矩、DataNode以及

DataSource。弄懂这些装备,是正确运用MyCat的前提。这里就一层层对该文件进行解析。

schema 标签用于界说MyCat实例中的逻辑库

Table 标签界说了MyCat中的逻辑表

dataNode 标签界说了MyCat中的数据节点,也便是咱们通常说所的数据分片。

dataHost标签在mycat逻辑库中也是作为最底层的标签存在,直接界说了详细的数据库实例、读写分离装备和心

跳语句。

注意:若是LINUX版别的MYSQL,则需求设置为Mysql大小写不敏感,不然可能会产生表找不到的问题。


在MySQL的装备文件中 vi /etc/my.cnf [mysqld] 中添加一行 lower_case_table_names=1


image.png


装备后重启mysql服务 service mysqld restart


MySQL在Linux找不到表名-处理疏忽大小写

http://blog.csdn.net/h254532699/article/details/54318478


2、创立数据库

在第一台服务器上创立数据库db1、db3

在第二台服务器上创立数据库db2

3、Schema.xml装备

schema中装备一个table节点

装备后重启mysql服务 service mysqld restart


http://org.opencloudb/”>









select user()







select user()


3、装备server.xml


server.xml简直保存了一切mycat需求的系统装备信息。最常用的是在此装备用户名、暗码及权限。


4、rule.xml


rule.xml里边就界说了咱们对表进行拆分所涉及到的规矩界说。咱们能够灵活的对表运用不同的分片算法,或者


对表运用相同的算法但详细的参数不同。这个文件里边主要有tableRule和function这两个标签。在详细运用过程


中能够依照需求添加tableRule


和function。


此装备文件能够不必修改,运用默许即可。


四、测验分片


1、创立表


装备结束后,重新启动mycat:


运用mysql客户端连接mycat,创立表 tb_item 的表结构。


2、插入数据

3、分片测验

因为装备的分片规矩为“auto-sharding-long”,所以mycat会根据此规矩自动分片。

每个datanode中保存必定数量的数据。根据id进行分片


经测验id范围为:


Datanode1:1~5000000


Datanode2:5000000~10000000


Datanode3:10000001~15000000


当15000000以上的id插入时报错:


[Err] 1064 - can’t find any valid datanode :TB_ITEM -> ID -> 15000001

此刻需求添加节点了。


本公司销售:阿里云、腾讯云、百度云、天翼云、金山大米云、金山企业云盘!可签订合同,开具发票。

我有话说: