环境:
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. [JCIP笔记] (三)如何设计一个线程安全的对象

    在当我们谈论线程安全时,我们在谈论什么中,我们讨论了怎样通过Java的synchronize机制去避免几个线程同时访问一个变量时发生问题.忧国忧民的Brian Goetz大神在多年的开发过程中,也悟到 ...

  2. 常用cmd代码片段及.net core打包脚本分享

    bat基础命令 注释:rem 注释~~ 输出:echo hello world 接收用户输入:%1 %2,第n个变量就用%n表示 当前脚本路径:%~dp0 当前目录路径:%cd% 设置变量:set c ...

  3. 关于PHP7

    目前一直使用php7也看了许多文档视频等,整理一下相关细节(仅为记录-),对于PHP7性能,如下图所示. * 在wordpress3.0.1中 php7比php5.6性能提升约3倍左右 新特性 一.变 ...

  4. 老帖收藏,留供参考:SpringMvc2.5+Mybatis3.2.7

    一.项目背景 SpringMvc+Mybatis 数据库连接池是阿里巴巴的druid.日志框架式logback 二.配置文件 1.SpringMvc-servlet.xml <?xml vers ...

  5. 英语词汇(2)fall down,fall off和fall over

    一.fall down,fall off和fall over都表示"摔倒.跌倒"的意思,但它们各自的含义不同. 1.fall over 落在...之上, 脸朝下跌倒 fall ov ...

  6. LDAP的用户需求

    使用LDAP(ApacheDS)构建统一认证服务(SSO单点登录)   构建团队协作的体系,需要涉及很多个系统,如SVN.Jenkins.Trac.Nexus等,而一般而言每个系统均有其用户体系,当我 ...

  7. 浅谈移动端适配-rem

    对于移动端开发来说,无可避免的就是直面各种设备不同分辨率和不同DPR(设备像素比)的问题,在此忽略其他兼容性问题的探讨. 一. 移动端开发有关于像素的概念: 1.设备像素(dp),也叫物理像素.指设备 ...

  8. POJ-2923 Relocation---01背包+状态压缩

    题目链接: https://vjudge.net/problem/POJ-2923 题目大意: 有n个货物,给出每个货物的重量,每次用容量为c1,c2的火车运输,问最少需要运送多少次可以将货物运完 思 ...

  9. hdu4864 Task贪心好题

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4864 题目大意: 有n个机器,m个任务.每个机器至多能完成一个任务.对于每个机器,有一个最大运行时间 ...

  10. vue中实现全选功能

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue ...