MyCat快速入门指南
来源:互联网 发布:毕加索美工钢笔推荐 编辑:程序博客网 时间:2024/05/16 14:31
1.下载mycat安装包
https://github.com/MyCATApache/Mycat-download
2.修改schema.xml文件
<writeHost host="hostM1" url="mysql服务IP:3306" user="root"
3.创建数据库
CREATE database db1;
CREATE database db2;
CREATE database db3;
4.建表
Employee表,是根据规则sharding-by-intfile (分片字段为sharding_id)进行分片。创建employee表:输入如下SQL
create table employee (id int not null primary key,name varchar(100),sharding_id int not null);
运行explain指令,查看该SQL被发往哪些分片节点执行:
explaincreate table employee (id int not null primary key,name varchar(100),sharding_id int not null);
建议参照schema.xml中employee表的定义,以及其分片规则,来看看什么数据会出现在dn1上,什么数据会出现在dn2上。
温馨提示:explain可以用于任何正确的SQL上,其作用是告诉你,这条SQL会路由到哪些分片节点上执行,这对于诊断分片相关的问题很有帮助。另外,explain可以安全的执行多次,它仅仅是告诉你SQL的路由分片,而不会执行该SQL。
插入数据:
insert into employee(id,name,sharding_id) values(1,'leader us',10000);
insert into employee(id,name,sharding_id) values(2, 'me',10010);
insert into employee(id,name,sharding_id) values(3, 'mycat',10000);
insert into employee(id,name,sharding_id) values(4, 'mydog',10010);
company表是根据规则auto-sharding-long(主键范围)进行分片。创建company表:输入如下SQL
create table company(id int not null primary key,name varchar(100));
录入数据:
insert into company(id,name) values(1,'hp');
insert into company(id,name) values(2,'ibm');
insert into company(id,name) values(3,'oracle');
你会看到三个分片上都插入了3条数据,因为company定义为全局表,用explain来确认这个情况:
explain insert into company(id,name) values(1,'hp')
返回3个节点的信息:
| DATA_NODE | SQL |
+-----------+---------------------------------------------+
| dn1 | insert into company(id,name) values(1,'hp') |
| dn2 | insert into company(id,name) values(1,'hp') |
| dn3 | insert into company(id,name) values(1,'hp') |
+-----------+---------------------------------------------+
创建客户表:
create customer: create table customer(id int not null primary key,name varchar(100),company_id int not null,sharding_id int not null);
插入数据:
insert into customer (id,name,company_id,sharding_id )values(1,'wang',1,10000); //stored in db1;
insert into customer (id,name,company_id,sharding_id )values(2,'xue',2,10010); //stored in db2;
insert into customer (id,name,company_id,sharding_id )values(3,'feng',3,10000); //stored in db1;
查询结果:
Select * from customer;
explain Select * from customer; (确认数据是分片存储)
创建表格orders,并插入数据:
create table orders (id int not null primary key ,customer_id int not null,sataus int ,note varchar(100) );
insert into orders(id,customer_id) values(1,1); //stored in db1 because customer table with id=1 stored in db1
insert into orders(id,customer_id) values(2,2); //stored in db2 because customer table with id=1 stored in db2
explain insert into orders(id,customer_id) values(2,2);
select customer.name ,orders.* from customer ,orders where customer.id=orders.customer_id;
travelrecord根据ID主键的范围进行分片:
create travelrecord: create table travelrecord (id bigint not null primary key,user_id varchar(100),traveldate DATE, fee decimal,days int);
insert into travelrecord (id,user_id,traveldate,fee,days) values(1,'wang','2014-01-05',510.5,3);这个ID就存放在分片0上了
explain insert into travelrecord (id,user_id,traveldate,fee,days) values(7000001,'wang','2014-01-05',510.5,3); 这个ID就存放在分片1上了
看到支持跨分片的JOIN!
热点新闻,用取摸的方式分配到dn1,dn2,dn3上
create table hotnews(id int not null primary key ,title varchar(400) ,created_time datetime);
插入数据
insert into hotnews(id,title,created_time) values(1,'first',now()); 在分片1上
而Id为5,则到dn3上,5%3=2 ,即对应dn3的 index
其他:
goods表(全局表)
create table goods(id int not null primary key,name varchar(200),good_type tinyint,good_img_url varchar(200),good_created date,good_desc varchar(500), price double);
5.在以上过程中你可以看到各种分片规则,就这样你就入门了。
- MyCat快速入门指南
- Mycat快速入门
- 数据库中间件-mycat快速入门
- RMAN快速入门指南
- RMAN快速入门指南
- Quartz快速入门指南
- MINA 快速入门指南
- android快速入门指南
- Spark快速入门指南
- MailCore 快速入门指南
- DragonBones快速入门指南
- DragonBones快速入门指南
- JDO快速入门指南
- DragonBones快速入门指南
- ExtJS快速入门指南
- Spark快速入门指南
- DragonBones快速入门指南
- GForms 快速入门指南
- linux下修改mysql的root密码
- Servlet实现文件上传,可多文件上传
- 浮动元素问题
- PCI Express
- javascript 事件
- MyCat快速入门指南
- 目标跟踪“Siamese Instance Search for Tracking”
- Android 代码规范
- Jquery给Div赋值
- [Python]网络爬虫(七):Python中的正则表达式教程
- 自己写bootloader笔记3---init.c分析
- Docker cpu memory quota使用说明
- 如何给 Web 服务器 Apache 和 Nginx 创建新的环境变量
- C++求斐波那契数列的第n项