环境:
centos7.4 + mysql5.7.20 + mycat1.6
单台主机上安装了5台mysql_5.7.20 实例(3306,3307,3308,3309,3310)
3306为独立实例 (db6,order_db,sequence_test)
3307为独立实例 (db7,order_db)

3308为主DB (db8,user_db) --GTID复制
3309为从DB(主3308)
3301为从DB(主3308)

一、环境创建

#创建mycat账号
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create user mycat6@'%' identified by ''; grant all privileges on *.* to mycat6@'%'; "
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e"create user mycat7@'%' identified by ''; grant all privileges on *.* to mycat7@'%'; "
mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e"create user mycat8@'%' identified by ''; grant all privileges on *.* to mycat8@'%'; " #创建数据库及表
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create database db6;"
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e"create database db7;"
mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e"create database db8;" mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e"create database user_db;" ##配读写分离
mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e"create table user_db.users(id int auto_increment primary key ,user_id int ,user_name varchar(12));" ##配读写分离 mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create database order_db;" ##配分片
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e"create database order_db;" ##配分片
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create table order_db.orders(id int auto_increment primary key ,user_id int ,order_id varchar(12));" ##配分片
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e"create table order_db.orders(id int auto_increment primary key ,user_id int ,order_id varchar(12));" ##配分片 mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create table db6.city(id int auto_increment primary key ,city_name varchar(16));" ##配全局表
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e"create table db7.city(id int auto_increment primary key ,city_name varchar(16));" ##配全局表
mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e"create table db8.city(id int auto_increment primary key ,city_name varchar(16));" ##配全局表 mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create database sequence_test;" ##全局序列库
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"create table sequence_test.MYCAT_SEQUENCE(name VARCHAR (50) NOT NULL PRIMARY KEY , current_value INT NOT NULL ,increment INT NOT NULL DEFAULT 100 ); " ##全局序列号表
mysql -uroot -p123456 -h127.0.0.1 -P 3306
use sequence_test ;
#取当前squence的值
mysql>
DROP FUNCTION IF EXISTS mycat_seq_currval;
DELIMITER $
CREATE FUNCTION mycat_seq_currval(seq_name VARCHAR(50)) RETURNS varchar(64) CHARSET utf8
DETERMINISTIC
BEGIN
DECLARE retval VARCHAR(64);
SET retval="-999999999,null";
SELECT concat(CAST(current_value AS CHAR),",",CAST(increment AS CHAR)) INTO retval FROM MYCAT_SEQUENCE WHERE name = seq_name;
RETURN retval;
END $
DELIMITER ;
#设置 sequence 值
mysql>
DROP FUNCTION IF EXISTS mycat_seq_setval;
DELIMITER $
CREATE FUNCTION mycat_seq_setval(seq_name VARCHAR(50),value INTEGER) RETURNS varchar(64) CHARSET utf8
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET current_value = value
WHERE name = seq_name;
RETURN mycat_seq_currval(seq_name);
END $
DELIMITER ;
#取下一个sequence的值
mysql>
DROP FUNCTION IF EXISTS mycat_seq_nextval;
DELIMITER $
CREATE FUNCTION mycat_seq_nextval(seq_name VARCHAR(50)) RETURNS varchar(64) CHARSET utf8
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET current_value = current_value + increment WHERE name = seq_name;
RETURN mycat_seq_currval(seq_name);
END $
DELIMITER ; mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e"use sequence_test;INSERT INTO MYCAT_SEQUENCE(name,current_value,increment) VALUES ('seq_test', 1, 100); " #全局序列号名称引用关系
#INSERT INTO MYCAT_SEQUENCE(name,current_value,increment) VALUES (【'seq_test'】, 1, 100); "
#【SEQ_TEST]】=dn_seq
#next value for MYCATSEQ_【SEQ_TEST】

二、文件配置

sequence_db_conf.properties 全局序列号文件配置
SEQ_TEST=dn_seq server.xml 文件配置(修改内容)
<system>
<property name="sequnceHandlerType">1</property> ##全局序列号
</system> <user name="mycat">
<property name="password">123456</property>
<property name="schemas">s_global_db,s_db6,s_db7,s_db8,s_user_db,s_order_db</property> ##mysql> show databases;看到的内容
</user> schema.xml 文件配置
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/"> <schema name="s_db6" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn6" > </schema>
<schema name="s_db7" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn7" > </schema>
<schema name="s_db8" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn8" > </schema>
<schema name="s_user_db" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn82" > </schema>
<schema name="s_order_db" checkSQLschema="false" sqlMaxLimit="100">
<table name="orders" primaryKey="id" autoIncrement="true" dataNode="dn62,dn72" rule="mod-long" /> ##分片表
</schema>
<schema name="s_global_db" checkSQLschema="false" sqlMaxLimit="100">
<table name="city" primaryKey="id" autoIncrement="true" type="global" dataNode="dn6,dn7,dn8" /> ##全局表
</schema> <dataNode name="dn6" dataHost="dh6" database="db6" />
<dataNode name="dn7" dataHost="dh7" database="db7" />
<dataNode name="dn8" dataHost="dh8" database="db8" />
<dataNode name="dn82" dataHost="dh8" database="user_db" />
<dataNode name="dn62" dataHost="dh6" database="order_db" /> ##分片表
<dataNode name="dn72" dataHost="dh7" database="order_db" /> ##分片表
<dataNode name="dn_seq" dataHost="dh6" database="sequence_test" /> ##全局序列号节点 <dataHost name="dh6" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="host6_M" url="127.0.0.1:3306" user="mycat6" password="123456"> </writeHost>
</dataHost> <dataHost name="dh7" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="host7_M" url="127.0.0.1:3307" user="mycat7" password="123456"> </writeHost>
</dataHost> <dataHost name="dh8" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="host8_M" url="127.0.0.1:3308" user="mycat8" password="123456"> ##读写分离
<readHost host="host8_S1" url="127.0.0.1:3309" user="mycat8" password="123456" />
<readHost host="host8_s2" url="127.0.0.1:3310" user="mycat8" password="123456" />
</writeHost>
</dataHost> </mycat:schema> rule.xml文件配置(修改内容)
<tableRule name="mod-long"> ##分片表(规则)
<rule>
<columns>user_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>

三、测试结果

测试分表及全局序列号结果:

mysql -umycat -p123456 -h127.0.0.1 -P 8066 -e "show databases;"
mysql -umycat -p123456 -h127.0.0.1 -P 8066 -e "use s_order_db ; "
mysql -umycat -p123456 -h127.0.0.1 -P 8066 -e "use s_order_db ; select * from orders; insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,1,'A01'); insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,2,'A02'); insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,3,'A03'); insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,4,'A04'); insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,5,'A05'); insert into orders(id,user_id,order_id) values (next value for MYCATSEQ_SEQ_TEST,7,'A07');"
mysql -uroot -p123456 -h127.0.0.1 -P 8066 -e "use s_order_db ; select * from orders; "
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e "use order_db ; select * from orders; "
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e "use order_db ; select * from orders; " 测试全局表结果:
mysql -umycat -p123456 -h127.0.0.1 -P 8066 -e "use s_global_db ; insert into city(id,city_name) values (null,'武汉'); insert into city(id,city_name) values (null,'深圳');"
mysql -umycat -p123456 -h127.0.0.1 -P 8066 -e "use s_global_db ; select * from city; "
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -e "use db6 ; select * from city; "
mysql -uroot -p123456 -h127.0.0.1 -P 3307 -e "use db7 ; select * from city; "
mysql -uroot -p123456 -h127.0.0.1 -P 3308 -e "use db8 ; select * from city; "

mycat 1.6 简单的操作实例的更多相关文章

  1. 安卓 SQLite数据库操作实例

    前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...

  2. 在安卓开发中使用SQLite数据库操作实例

    前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...

  3. 审核流(3)低调奢华,简单不凡,实例演示-SNF.WorkFlow--SNF快速开发平台3.1

    下面我们就从什么都没有,结合审核流进行演示实例.从无到有如何快速完美的实现,然而如此简单.低调而奢华,简单而不凡. 从只有数据表通过SNF.CodeGenerator代码生成器快速生成单据并与审核流进 ...

  4. 初学redux笔记,及一个最简单的redux实例

    categories: 笔记 tags: react redux 前端框架 把初学redux的一些笔记写了下来 分享一个入学redux很合适的demo, 用redux实现计数器 这是从阮一峰老师git ...

  5. ado.net的简单数据库操作(一)

    摘要:接下来的几篇博客将要讲到如何使用ado.net实现简单的数据库操作,包括增删改等内容.首先会介绍基础的数据库操作,然后以一个实例来进行讲解,这个实例会把一个数据表读取到winform上,然后在w ...

  6. selenium--控制浏览器和简单元素操作

    控制浏览器1.driver.maximize_window() #浏览器最大化2.driver.set_windows_size(480*800) #浏览器设置成移动端大小(480*800),参数数字 ...

  7. 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(二)(代码篇)

    这篇是上一篇的延续: 用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一) 源代码在github上可以下载,地址:https://github.com/guoxia ...

  8. 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一)

    梳理下使用spring+springMVC+mybatis 整合后的一个简单实例:输入用户的 ID,之后显示用户的信息(此次由于篇幅问题,会分几次进行说明,此次是工程的创建,逆向生成文件以及这个简单查 ...

  9. 简单是Jedis实例(相对连接池而言)

    在引入相关jar包后,只要new一个Jedis对象,就能做redis相关操作了.以下是一个简单的jedis实例: package com.pptv.redis; import java.util.Ar ...

随机推荐

  1. Linux 下的权限改变与目录配置

    Linux 下的权限改变与目录配置 ./代表本目录的意思. (1):用户与用户组, 1:文件所有者,文件被某一用户所有 2:用户组:    对文件给与一个或者多个用户权限配置 3:其它人: (2):l ...

  2. java图片处理开源框架

    java图片处理开源框架 以前一直不明白,java开源框架什么意思,搜集资料得出以下结论 其实java框架可以理解为一个工具或者一个插件,将一个公用的.常用的技术封装起来,处理一些基础的.繁琐的问题. ...

  3. 新概念英语(1-103)The French Test

    Lesson 103 The French test 法语考试 Listen to the tape then answer this question. How long did the exam ...

  4. Python 自动化 第一周

    1.Python简介 1.1.Python介绍 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时 ...

  5. python开发:python字符串操作方法

    name = "my \tname is {name} and i am {year} old" capitalize:第一个单词的首字母大写的方法 print(name.capi ...

  6. 高级控件之Scrollview ( 滑动屏幕 ) 与 Imageview (滑动屏幕 切换图片)

    ScrollView  的xml布局 <?xml version="1.0" encoding="utf-8"?> <RelativeLayo ...

  7. JavaScript的sleep实现--Javascript异步编程学习

    一.原始需求 最近在做百度前端技术学院的练习题,有一个练习是要求遍历一个二叉树,并且做遍历可视化即正在遍历的节点最好颜色不同 二叉树大概长这个样子: 以前序遍历为例啊, 每次访问二叉树的节点加个sle ...

  8. Spark:如何替换sc.parallelize(List(item1,item2)).collect().foreach(row=>{})为并行?

    代码场景: 1)设定的几种数据场景,遍历所有场景:依次统计满足每种场景条件下的数据,并把统计结果存入hive: 2)已有代码如下: case class IndoorOTTCalibrateBuild ...

  9. 用委托(Delegate)的BeginInvoke和EndInvoke方法操作线程

    让我们首先了解下什么时候用到C#异步调用: .NET Framework 允许您C#异步调用任何方法.定义与您需要调用的方法具有相同签名的委托:公共语言运行库将自动为该委托定义具有适当签名的Begin ...

  10. bcrypt对密码加密的一些认识(学习笔记)

    学习nodejs和mongoDB的时候,接触了用户注册和登录的一些知识. 1.关于增强用户密码的安全性 用户的密码肯定不能保存为明文,避免撞库攻击. 撞库攻击:撞库是一种针对数据库的攻击方式,方法是通 ...