MyCat分片:水平拆分例項解析和程式碼實現!
一、概述
根據表中的資料的邏輯關係,將
同一個表中的資料按照某種條件拆分到多臺資料庫(主機)上面,這種切分稱之為
資料的水平(橫向)切分。
二、案例場景
在業務系統中, 有一張表(日誌表), 業務系統每天都會產生大量的日誌資料 , 單臺伺服器的資料儲存及處理能力是有限的, 可以對資料庫表進行拆分, 原有的資料庫表拆分成以下表 :
三、準備工作
1.準備三臺資料庫例項
192.168.192.157 192.168.192.158 192.168.192.159
2.在三臺資料庫例項中建立資料庫
create database log_db DEFAULT CHARACTER SET utf8mb4;
四、schema.xml的配置
<?xml version="1.0"?> <!DOCTYPE mycat:schema SYSTEM "schema.dtd"> <mycat:schema xmlns:mycat="
<schema name="LOG_DB" checkSQLschema="false" sqlMaxLimit="100">
<table name="tb_log" dataNode="dn1,dn2,dn3" primaryKey="id" rule="mod- long" />
</schema>
<dataNode name="dn1" dataHost="host1" database="log_db" />
<dataNode name="dn2" dataHost="host2" database="log_db" />
<dataNode name="dn3" dataHost="host3" database="log_db" />
<dataHost name="host1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="192.168.192.157:3306" user="root" password="itcast"></writeHost>
</dataHost>
<dataHost name="host2" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM2" url="192.168.192.158:3306" user="root" password="itcast"></writeHost>
</dataHost>
<dataHost name="host3" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM3" url="192.168.192.159:3306" user="root" password="itcast"></writeHost>
</dataHost> </mycat:schema>
五、server.xml的配置
<user name="root" defaultAccount="true">
<property name="password">123456</property>
<property name="schemas">LOG_DB</property> </user> <user name="test">
<property name="password">123456</property>
<property name="schemas">LOG_DB</property> </user> <user name="user">
<property name="password">123456</property>
<property name="schemas">LOG_DB</property>
<property name="readOnly">true</property> </user>
六、測試
1.在MyCat資料庫中執行建表語句
CREATE TABLE `tb_log` (
`id` bigint(20) NOT NULL COMMENT 'ID',
`model_name` varchar(200) DEFAULT NULL COMMENT '模組名',
`model_value` varchar(200) DEFAULT NULL COMMENT '模組值',
`return_value` varchar(200) DEFAULT NULL COMMENT '返回值',
`return_class` varchar(200) DEFAULT NULL COMMENT '返回值型別',
`operate_user` varchar(20) DEFAULT NULL COMMENT '操作使用者',
`operate_time` varchar(20) DEFAULT NULL COMMENT '操作時間',
`param_and_value` varchar(500) DEFAULT NULL COMMENT '請求引數名及引數值',
`operate_class` varchar(200) DEFAULT NULL COMMENT '操作類',
`operate_method` varchar(200) DEFAULT NULL COMMENT '操作方法',
`cost_time` bigint(20) DEFAULT NULL COMMENT '執行方法耗時, 單位 ms',
`source` int(1) DEFAULT NULL COMMENT '來源 : 1 PC , 2 Android , 3 IOS',
PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
2.插入資料
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`, `return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`, `operate_method`, `cost_time`,`source`)
VALUES('1','user','insert','success','java.lang.String','10001','2020-02-26 18:12:28','{\"age\":\"20\",\"name\":\"Tom\",\"gender\":\"1\"}','cn.itcast.controller.UserController','insert','10',1);
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`,`return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`, `operate_method`, `cost_time`,`source`)
VALUES('2','user','insert','success','java.lang.String','10001','2020-02-26 18:12:27','{\"age\":\"20\",\"name\":\"Tom\",\"gender\":\"1\"}','cn.itcast.controller.UserController','insert','23',1);
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`, `return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`, `operate_method`, `cost_time`,`source`)
VALUES('3','user','update','success','java.lang.String','10001','2020-02-26 18:16:45','{\"age\":\"20\",\"name\":\"Tom\",\"gender\":\"1\"}','cn.itcast.controller.UserController','update','34',1);
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`, `return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`, `operate_method`, `cost_time`,`source`)
VALUES('4','user','update','success','java.lang.String','10001','2020-02-26 18:16:45','{\"age\":\"20\",\"name\":\"Tom\",\"gender\":\"1\"}','cn.itcast.controller.UserController','update','13',2);
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`, `return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`, `operate_method`, `cost_time`,`source`)
VALUES('5','user','insert','success','java.lang.String','10001','2020-02-26 18:30:31','{\"age\":\"200\",\"name\":\"TomCat\",\"gender\":\"0\"}','cn.itcast.cont roller.UserController','insert','29',3);
INSERT INTO `tb_log` (`id`, `model_name`, `model_value`, `return_value`,`return_class`, `operate_user`,
`operate_time`, `param_and_value`, `operate_class`,`operate_method`, `cost_time`,`source`)
VALUES('6','user','find','success','java.lang.String','10001','2020-02 2618:30:31','{\"age\":\"200\",\"name\":\"TomCat\",\"gender\":\"0\"}','cn.itcast.cont roller.UserController','find','29',2);
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69964492/viewspace-2764217/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- jQuery實現的div垂直水平居中例項程式碼jQuery
- css實現div全屏水平垂直居中效果程式碼例項CSS
- css實現的div垂直水平居中程式碼例項CSS
- css3實現元素垂直水平居中程式碼例項CSSS3
- MyCat分片:分片規則的十四種演算法詳細解讀&程式碼實現(上篇)演算法
- css3實現div元素垂直水平居中程式碼例項CSSS3
- div垂直水平居中例項程式碼
- jquery實現的解析xml檔案程式碼例項jQueryXML
- jQuery實現的彈出垂直水平居中視窗效果程式碼例項jQuery
- css水平垂直居中程式碼例項CSS
- javascript元素水平運動程式碼例項JavaScript
- javascript div水平運動程式碼例項JavaScript
- CSS讓div水平居中例項程式碼CSS
- css實現梯形程式碼例項CSS
- 公告文字水平滾動例項程式碼
- css多元素水平居中效果程式碼例項CSS
- javascript文字水平滾動程式碼例項JavaScript
- Mycat中介軟體實現Mysql資料分片( 下篇)MySql
- Mycat中介軟體實現Mysql資料分片(上篇)MySql
- jquery實現的下拉和收縮程式碼例項jQuery
- jquery實現的讀取並解析xml檔案程式碼例項jQueryXML
- css實現對聯程式碼例項CSS
- canvas實現的刮刮樂程式碼例項Canvas
- css水平下拉導航選單程式碼例項CSS
- css設定div水平居中程式碼例項CSS
- ul和li實現的新聞列表程式碼例項
- 調整視窗大小也能夠實現div水平垂直居中程式碼例項
- javascript實現的驗證碼程式碼例項JavaScript
- jQuery實現的tab選項卡程式碼例項jQuery
- jquery實現的選項卡效果例項程式碼jQuery
- javascript實現animate()動畫效果程式碼例項JavaScript動畫
- javascript實現的補零程式碼例項JavaScript
- js實現jquery的extend()程式碼例項JSjQuery
- js實現的警告框例項程式碼JS
- js實現文字框提示程式碼例項JS
- css實現矩形切角效果程式碼例項CSS
- canvas實現的美猴王程式碼例項Canvas
- jQuery實現滑動門程式碼例項jQuery