mycat分库分表的情况下,原生mysql的自增长主键无法满足主键全局唯一这个要求。看了MYCAT社区从零开始的一篇博客,加上自己的实践,大概总结一下。

  目前mycat对于全局sequence主要提供2种方法,本地文件方式和数据库方式。

 

  1.本地文件:

  本地文件的方式配置很简单,只需要修改2个文件即可。首先在conf下的servel.xml中添加:  

<property name="sequnceHandlerType">0</property>

  然后再sequence_conf.properties中配置:

  TEST.HISIDS=
TEST.MINID=1001
TEST.MAXID=200000
TEST.CURID=1000

  注:TEST为自定义的名称,建议根据各个表的表名进行命名,比如TEST就为tab_test表的主键seq。

  MINID为最小seq,MAXID为最大seq,CURID为目前seq的值。

  保存退出,通过 select next value for MYCAT_TEST即可测试是否成功。

  2.数据库方式:

   还是首先配置server.xml  

<property name="sequnceHandlerType">1</property>

  然后选择一个数据库,我这里选择的是本机mysql中的db1,对应的dataNode是dn1。登陆mysql(非mycat),执行脚本:

  

DROP TABLE IF EXISTS MYCAT_SEQUENCE;
CREATE TABLE MYCAT_SEQUENCE ( name VARCHAR(50) NOT NULL, current_value INT NOT NULL, increment INT NOT NULL DEFAULT 100, PRIMARY KEY (name) ) ENGINE=InnoDB;
-- ----------------------------
-- Function structure for `mycat_seq_currval`
-- ----------------------------
DROP FUNCTION IF EXISTS `mycat_seq_currval`;
DELIMITER ;;
CREATE DEFINER=`root`@`%` FUNCTION `mycat_seq_currval`(seq_name VARCHAR(50)) RETURNS varchar(64) CHARSET latin1
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 ;
-- ----------------------------
-- Function structure for `mycat_seq_nextval`
-- ----------------------------
DROP FUNCTION IF EXISTS `mycat_seq_nextval`;
DELIMITER ;;
CREATE DEFINER=`root`@`%` FUNCTION `mycat_seq_nextval`(seq_name VARCHAR(50)) RETURNS varchar(64) CHARSET latin1
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET current_value = current_value + increment WHERE name = seq_name;
RETURN mycat_seq_currval(seq_name);
END
;;
DELIMITER ;
-- ----------------------------
-- Function structure for `mycat_seq_setval`
-- ----------------------------
DROP FUNCTION IF EXISTS `mycat_seq_setval`;
DELIMITER ;;
CREATE DEFINER=`root`@`%` FUNCTION `mycat_seq_setval`(seq_name VARCHAR(50), value INTEGER) RETURNS varchar(64) CHARSET latin1
DETERMINISTIC
BEGIN
UPDATE MYCAT_SEQUENCE
SET current_value = value
WHERE name = seq_name;
RETURN mycat_seq_currval(seq_name);
END
;;
DELIMITER ;
INSERT INTO MYCAT_SEQUENCE VALUES ('GLOBAL', 0, 100);
SELECT MYCAT_SEQ_SETVAL('GLOBAL', 1);
SELECT MYCAT_SEQ_CURRVAL('GLOBAL');
SELECT MYCAT_SEQ_NEXTVAL('GLOBAL');
4.插入序列数据:
INSERT INTO MYCAT_SEQUENCE VALUES ('GLOBAL', 0, 100);
INSERT INTO MYCAT_SEQUENCE VALUES ('GLOBAL', 0, 100);

  这里我贴上博主从零开始的解释:

    

  说明:

  • 在某个分区(dataNode)数据库上创建序列号相关的表格和函数,SQL脚本在doc目录下的sequnce-sql.txt中,需要在数据库上而非Mycat上执行。
  • Mycat_home/conf/quence_db_conf.properties 中记录了sequnce所存放的db对应的配置信息。
  #sequence stored in datanode
  GLOBAL=dn1
  COMPANY=dn1
  CUSTOMER=dn1
  • 在sequnce表中,插入相应的sequnce记录,并确定其初始值,以及增长步长,步长建议一个合适的范围,比如50-500,需要在数据库上而非Mycat上执行。
  INSERT INTO MYCAT_SEQUENCE VALUES ('GLOBAL', 0, 100);
  • 修改sequnce的当前值为某个新值,需要在数据库上而非Mycat上执行。
  SELECT mycat_seq_curval('GLOBAL');

  提示:步长选择多大,取决与你数据插入的TPS,假如是每秒1000个,则步长为1000×60=6万,也不是很大,即60秒会重新从数据库读取下一批次的序列号值。

   最后,修改mycat配置文件sequence_db_conf.properties

    GLOBAL=dn1

    TEST=dn1

   通过 select next value for MYCATSEQ_GLOBAL可以进行测试。

    

最新文章

  1. easyX最新版在VS2015上的问题解决啦啦
  2. Objective-c——UI进阶开发第一天(UIPickerView和UIDatePicker)
  3. try...except 抛出错误
  4. 计算机硕士工资一览表 08年最新各大IT公司薪水行
  5. 网站如何做到完全不需要jQuery
  6. Linux网络地址转换分析
  7. [新]最近用unity5弄的一些渲染
  8. get the first and last collection item in Magento
  9. Effective JavaScript :第一章
  10. Java中的回调函数学习
  11. git clone失败
  12. linux下tomcat服务器的相关命令
  13. sci-hub免费下载论文
  14. Tomcat server.xml中Connector配置参数详解
  15. c语言-遍历pci设备(1)io访问
  16. Core Animation之基础介绍
  17. Linux 安装 Oracle 11g R2
  18. android switch控件
  19. k:特殊的线性表—队列
  20. 微信小程序测试的策略和注意事项

热门文章

  1. Java_HTTP_01_HttpClient
  2. redis数据
  3. 理解I/O Completion Port(完成端口)
  4. ESFramework Demo -- P2P通信Demo(附源码)
  5. hdu 3625 Examining the Rooms —— 第一类斯特林数
  6. Python实例浅谈之五Python守护进程和脚本单例运行
  7. C# 使用 MemoryStream 将数据写入内存
  8. openStack高可用性和灾备方案
  9. MD04
  10. [poj1830]开关问题(高斯消元)