Mycat 全局系列號

来源:http://www.cnblogs.com/chenmh/archive/2016/01/20/5142943.html
-Advertisement-
Play Games

標簽:utf8概述本篇文章介紹mycat怎樣在分庫分表的情況下保證主鍵的全局唯一方法,接下來就來分析三種方法各自的優缺點。配置文件方式獲取1.修改server配置文件vim server.xml0註:sequnceHandlerType 配置為0表示使用本地文件讀取。2.配置sequence_con...


標簽:utf8

概述  

本篇文章介紹mycat怎樣在分庫分表的情況下保證主鍵的全局唯一方法,接下來就來分析三種方法各自的優缺點。

 

配置  

文件方式獲取

1.修改server配置文件

 vim server.xml

<system><property name="sequnceHandlerType">0</property></system>
註:sequnceHandlerType 配置為0表示使用本地文件讀取。

 

2.配置sequence_conf.properties配置文件

3.在mycat中運行語句測試(在邏輯庫中測試)

insert into company(id,name) values(next value for MYCATSEQ_GLOBAL,'test');

缺點:在 MyCAT 重啟後,配置文件中癿 sequence 會恢復到初始值。
優點:本地載入,讀取速度較快。

 

資料庫方式獲取

1.修改server配置文件

 vim server.xml

<system><property name="sequnceHandlerType">1</property></system>
註:sequnceHandlerType 配置為1表示從資料庫表中讀取。

2.配置讀取的節點,就是配置全局表在哪個節點上面,我這裡配置在dn1節點上面。

vim sequence_db_conf.properties

 3.創建全局表和函數

選擇mysql物理庫的dn1節點上執行下麵語句,我配置的dn1即db1資料庫

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 ;


INSERT INTO MYCAT_SEQUENCE(name,current_value,increment) VALUES ('GLOBAL', 100000, 100);

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 ;

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 ;


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 ;

 4.測試插入數據,也是在mycat邏輯庫上執行

insert into user(id,name) values(next value for MYCATSEQ_GLOBAL,'中文');


優點:在 MyCAT 重啟後,sequence 值不會被初始化,比如當前MYCAT_SEQUENCE的初始值是100000,當mycat的重啟之後再執行插入數據後MYCAT_SEQUENCE的初始值就加100變成100100,新插入到表的值也是在加100的基礎上開始遞增,

缺點:當配置了主從複製時(A主B從),一開始主從上面的MYCAT_SEQUENCE表的current_value初始值是100000;當前配置的讀寫分離方案是A負責寫B負責讀當A宕機之後B負責寫A變成了讀,加入現在的全局ID已經到了 100103,這個時候如果A宕機了,

mycat應該是存在緩存current_value還是記錄的是A的值,不會立馬切換使用B上的current_value的值,如果這個時候mycat重啟了,這個時候全局系列號就開始使用B中的current_value值由於B值也是從100100開始那麼這個時候插入全局記錄到B中的表中就會和之前生成的100100到100103主鍵衝突了。不知道這算不算是一個BUG,所以當A宕機之後需要趕緊把A重啟好,這樣的話就算mycat重啟之後還是從A開始讀,這個時候全局ID就從100200開始了。

還有一種方法是當A宕機之後由於mycat還沒有重啟全局序列的ID還是緩存之前A的,這個時候把B的current_value增加100,這個時候如果切換到了A由於B的值是從100100開始不會和之前的衝突,如果這個時候A修複啟動了這個時候也要把A的current_value增加200避免切換到A之後又和現在的值衝突。

 

本地時間戳方式獲取

1.修改server配置文件

 vim server.xml

<system><property name="sequnceHandlerType">2</property></system>
註:sequnceHandlerType 配置為2表示時間戳方式。

 

2.測試插入數據,也是在mycat邏輯庫上執行,註意時間戳的長度有18位,保證表的欄位長度足夠

insert into user(id,name) values(next value for MYCATSEQ_GLOBAL,'中文');

優點:不存在上面兩種方案因為mycat的重啟導致id重覆的現象

缺點:數據類型太長

總結

 三種方式各有優缺點,根據自己的需求選擇。

 

 

 

備註:

    作者:pursuer.chen

    博客:http://www.cnblogs.com/chenmh

本站點所有隨筆都是原創,歡迎大家轉載;但轉載時必須註明文章來源,且在文章開頭明顯處給明鏈接。

《歡迎交流討論》


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 參考:http://www.cnblogs.com/hubli/p/4835549.html效果圖:1.wevbview_progressbar.xml ...
  • 主要用於UITableView和UICollectionView,也可以用於UIScrollView,其實主要是前兩個會用到空白或者網路出錯頁 採用給UIScrollView添加代理方法來給頁面添加空白頁,源碼很有學習意義
  • 文章內容大綱1、NSMutableAttributedString的基本使用2、NSMutableAttributedString的簡易封裝3、使用開源代碼GOBMarkupPaser處理富文本4、UITextKit簡介5、編程思想的相關思考前言富文本使用案例:這裡我自己也用了富文本實現了簡單的卻也...
  • 一、沙盒(SandBox) 1.沙盒機制 1> 每個應用都有屬於自己的存儲空間,即沙盒。 2> 應用只能訪問自己的沙盒,不可訪問其他區域。 3> 如果應用需要進行文件操作,則必須將文件存放在沙盒中,尤其是資料庫文件,在電腦上操作時,可以去訪問,但是如果要裝在真機上可以使用,必須將資料庫文件...
  • 最近有學生做畢業設計,想使用懸浮窗這種效果,其實很簡單,我們可以通過系統服務WindowManager來實現此功能,本章我們來試驗一下在當前Activity之上創建一個懸浮的view。第一步:認識WindowManagerl 這個介面用於與 window manager (視窗管理器, 應用框架.....
  • 使用Microsoft SQL SERVER 2014 Management Studio訪問Azure SQL Database時,查看存儲過程時遇到下麵錯誤信息: TITLE: Microsoft SQL Server Management Studio --------------------...
  • 在SQL標準中定義了四種隔離級別,每一種級別都規定了一個事務中所做的修改,哪些是在事務內和事務間可見的,哪些是不可見的。較低級別的隔離通常可以執行更高的併發,系統的開銷也更低。1、未提交讀(Read uncommitted)在未提交讀級別,事務中的修改,即使沒有提交,對其他事務也都是可見的。事務可以...
  • 功能說明:備份和恢復SQL Server資料庫* 作者: 劉功勛;* 版本:V0.1(C#2.0);時間:2007-1-1* 當使用SQL Server時,請引用 COM組件中的,SQLDMO.dll組件* 當使用Access中,請瀏覽添加引用以下兩個dll* 引用C:/Program Files/...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...