Springboot は Baidu のオープンソース分散 ID ジェネレータ UIDGenerator を統合します

Springboot は Baidu のオープンソース分散 ID ジェネレータ UIDGenerator を統合します

[[411081]]

環境: sprinboot2.3.12.RELEASE + uid-generator1.0.0

導入

UidGenerator は、Java で実装され、Snowflake アルゴリズムに基づいた一意の ID ジェネレーターです。 UidGenerator は、アプリケーション プロジェクト内でコンポーネントとして動作し、カスタムの workerId 数字と初期化戦略をサポートし、Docker などの仮想化環境での自動インスタンス再起動やドリフトなどのシナリオに適しています。実装の面では、UidGenerator は将来の時間を借用することでシーケンスの自然な並行性の制限を解決します。 RingBuffer は、生成された UID をキャッシュし、UID の生成と消費を並列化し、同時に CacheLine を埋めるために使用され、RingBuffer によって発生するハードウェア レベルの「誤った共有」問題を回避します。最終的には、単一マシンの QPS は 600 万に達します。

依存関係バージョン: Java 8 以上、MySQL (組み込みの WorkerID アロケータ、起動時に DB を通じて割り当てられます。カスタマイズされている場合、DB は必須の依存関係ではありません)

スノーフレークアルゴリズム


スノーフレーク アルゴリズムの説明: 指定されたマシンと同時および特定の同時シーケンスは一意です。これに基づいて、64 ビットの一意の ID (long) を生成できます。デフォルトのバイト割り当て方法は上記のとおりです。

  • sign(1bit) 固定 1 ビットの符号識別子。つまり、生成される UID は正の数です。
  • デルタ秒(28ビット)現在の時刻は、タイムベースポイント「2016-05-20」を基準として秒単位で表され、最大約8.7年までサポートできます。
  • ワーカー ID (22 ビット) マシン ID。最大約 420 万台のマシン起動をサポートできます。組み込み実装は、起動時にデータベースによって割り当てられます。デフォルトの割り当て戦略は「使用して忘れる」であり、再利用戦略は後で提供できます。
  • シーケンス (13 ビット) 1 秒あたりの同時接続数。 13 ビットでは、1 秒あたり 8192 の同時接続をサポートできます。

上記のパラメータはSpringを通じてカスタマイズできます。

キャッシュされたUidジェネレータ

RingBuffer は円形配列であり、配列の各要素がスロットになります。デフォルトでは、RingBuffer の容量は、Snowflake アルゴリズムのシーケンスの最大値、つまり 2^N です。 boostPower 構成を通じて容量を拡張し、RingBuffer の読み取りおよび書き込みスループットを向上させることができます。

テール ポインターとカーソル ポインターは、円形配列のスロットの読み取りと書き込みに使用されます。

  • テール ポインターは、プロデューサーによって生成された最大シーケンス番号を示します (このシーケンス番号は 0 から始まり、増加し続けます)。 Tail は Cursor を超えることはできません。つまり、プロデューサーは未使用のスロットを上書きできません。 Tailがcurosrに追いついたら、rejectedPutBufferHandlerを通じてPutRejectPolicyを指定できます。
  • カーソル ポインターは、コンシューマーによって消費される最小のシーケンス番号を表します (シーケンス番号のシーケンスはプロデューサのシーケンスと同じです)。カーソルはテールを超えることはできません。つまり、未生成のスロットを消費することはできません。カーソルが末尾に追いついたら、rejectedTakeBufferHandlerを通じてTakeRejectPolicyを指定できます。

CachedUidGenerator はデュアル リング バッファを使用します。Uid-RingBuffer は Uid を保存するために使用され、Flag-RingBuffer は Uid ステータス (埋められるかどうか、消費できるかどうか) を保存するために使用されます。

配列要素はメモリ内に連続的に割り当てられるため、CPU キャッシュを最大限に活用してパフォーマンスを向上させることができます。しかし、それは「偽りの共有」の問題も引き起こすでしょう。このため、Tail、Cursor ポインター、Flag-RingBuffer では CacheLine パディング方式が使用されます。


リングバッファ充填時間

  • 事前に入力された RingBuffer を初期化します。初期化すると、RingBuffer 全体が事前に入力されます。
  • テイク消費をリアルタイムで埋める際、残りの使用可能スロット(末尾 - カーソル)をリアルタイムで確認します。設定されたしきい値より少ない場合は、空きスロットを埋めます。しきい値は paddingFactor を通じて設定できます。クイック スタートの CachedUidGenerator 構成を参照してください。
  • 空きスロットを定期的に埋めるために、スケジュール スレッドを通じて定期的な埋め合わせが行われます。 scheduleInterval を使用して、スケジュールされた充填機能を設定し、スケジュールの時間間隔を指定できます。

上記はBaiduの公式紹介です。次に、これを Springboot プロジェクトに統合します。

UIDGenerator ダウンロード

uid-generatorを次のアドレスからダウンロードしてください


UIDGenerator 環境設定

テーブルを作成

  1. 落とす テーブルが存在する場合、WORKER_NODE;
  2. 作成する テーブルWORKER_NODE
  3. IDビッグイント ない  NULL AUTO_INCREMENT COMMENT '自動増分ID' ,
  4. HOST_NAME VARCHAR (64)なし  NULL COMMENT 'ホスト名'
  5. ポート・ヴァーチャー 64)   NULLコメント'ポート'
  6. タイプINT  ない  NULL COMMENT 'ノードタイプ: ACTUAL または CONTAINER'
  7. LAUNCH_DATE日付 ない  NULLコメント「発売日」
  8. 変更されたタイムスタンプ ない  NULLコメント'更新時刻'
  9. 作成日時 ない  NULLコメント「作成時刻」
  10. 主要な キー(ID)
  11. )COMMENT= 'UID ジェネレーターの DB WorkerID アサイナー' 、ENGINE = INNODB;

そのプロジェクト内のmapper.xmlファイルを、WorkerNodeEntity、WorkerNodeDAOに対応する自分のプロジェクトにコピーします。

DisposableWorkerIdAssigner が独自のプロジェクトにコピーされます。

DisposableWorkerIdAssigner は主に、注入された DAO を変更します。ここでは、デフォルトの DAO 関連の設定を変更する必要があるためです。

プロジェクト構成

頼る

  1. <依存関係>
  2. <グループID>mysql</グループID>
  3. <artifactId>mysql-コネクタ-java</artifactId>
  4. <scope>ランタイム</scope>
  5. </依存関係>
  6. <依存関係>
  7. <グループ ID>org.mybatis.spring.boot</グループ ID>
  8. <artifactId>mybatis-spring-boot-starter</artifactId>
  9. <バージョン>2.1.4</バージョン>
  10. </依存関係>
  11. <依存関係>
  12. <groupId>com.github.pagehelper</groupId>
  13. <artifactId>ページヘルパー-スプリングブートスターター</artifactId>
  14. <バージョン>1.3.0</バージョン>
  15. </依存関係>

mybatisの設定

  1. ページヘルパー:
  2. ヘルパー方言: mysql
  3. 合理的:本当 
  4. ページサイズゼロ: true  
  5. ページ番号としてオフセット: true  
  6. 行境界カウント: true  
  7. ---  
  8. マイバティス:
  9. タイプエイリアスパッケージ: com.pack.domain
  10. マッパーの場所:
  11. - クラスパス:/mappers/*.xml
  12. 構成:
  13. 遅延読み込みが有効: false  
  14. 積極的な遅延読み込み: false   

マッパー ファイル内の名前空間と対応するドメインを独自のパスに変更します。

UIDGenerator の設定

  1. @構成
  2. パブリッククラスUIDConfig{
  3.      
  4. @ビーン
  5. パブリックDefaultUidGenerator defaultUidGenerator(DisposableWorkerIdAssigner disposableWorkerIdAssigner) {
  6. デフォルトのUidGenerator defaultUidGenerator = 新しい DefaultUidGenerator();
  7. デフォルトの UidGenerator.setWorkerIdAssigner(使い捨ての WorkerIdAssigner);
  8. デフォルトUidGenerator.setTimeBits(29);
  9. デフォルトUidGenerator.setWorkerBits(21);
  10. デフォルトUidGenerator.setSeqBits(13);
  11. デフォルトのUidGenerator.setEpochStr( "2021-01-01" );
  12. defaultUidGeneratorを返します
  13. }
  14.  
  15. }

ご了承ください

DisposableWorkerIdAssigner は Baidu によって提供されるものではなく、独自のプロジェクトにコピーされます。

  1. @成分
  2. パブリッククラス DisposableWorkerIdAssigner は WorkerIdAssigner を実装します {
  3. @リソース
  4. プライベート WorkerNodeMapper workerNodeDAO;
  5. // その他のコード
  6. }

これですべての設定が完了しました。

テスト

  1. @リソース
  2. プライベート DefaultUidGenerator uidGenerator;
  3.      
  4. @テスト
  5. パブリックボイドテストジェネレータID(){
  6. ( int i = 0; i < 10; i++) {
  7. System.out .println (uidGenerator.getUID());
  8. }
  9. }


完了!!!

<<:  2020年、わが国のクラウドコンピューティング市場の規模は1,781億元に達し、成長率は33.6%でした。

>>:  面接で必ず聞かれるJVMランタイムデータ領域について理解していますか?

推薦する

競合サイト間では競争はあるものの学習は行われていない

ウェブサイトを最適化する方法の過程で、多くの経験共有で競合他社から学ぶことが言及されています。 どの...

大規模モデル分散並列技術 - データ並列最適化

コミュニケーションの融合上記から、各モデル勾配はデータ並列処理で同期される必要があることがわかります...

顧客を説得するSEOプランの作り方

SEO 計画の作成には通常、概要、Web サイトの構造、キーワードの検出と分析、SEO 計画と予測結...

nodeserv - $5.59/Kvm/2IP/4 コア/1G メモリ/50g ハードディスク/3T トラフィック

フロリダのゴラック データ センターでホストされている VPS ベンダーの Nodeserv が、V...

#黑5# 最も買う価値がある「VPS」に関する情報のまとめ。見逃すと、また1年待たなければなりません!

今年のブラックフライデーの VPS プロモーションは、実際にはかなりの数の人々を多かれ少なかれ不満に...

コレクション: 動的 IP 付き VPS、動的 IP VPS、切り替え可能な IP

香港のダイナミック IP VPS、台湾のダイナミック IP VPS、米国のダイナミック IP VPS...

Pinduoduoには「ViyaとLi Jiaqi」は必要ないのでしょうか?

過去2年間で、ライブストリーミング電子商取引は活況を呈する新しい経済産業となり、ライブストリーミング...

優れたオンライン顧客サービスに必要な 8 つの基本的な特性

入札プロモーションのコストがますます高くなるにつれて、優れたオンラインカスタマーサービスがますます重...

WeChat 張小龍: 良いユーザーエクスペリエンスとは何でしょうか?

編集者注: 優れたユーザー エクスペリエンスとは何でしょうか? これは誰もが求めている質問であり、人...

内部リンクは王様、外部リンクは最も重要

今日は「道元武術」というタイトルで、内部リンク構築の重要性を強調したいと思います。ウェブサイトの構築...

多様化する検索ニーズの中でSEOとして何をする必要があるのでしょうか?

多様化した検索ニーズは、実は非常に単純な概念です。同じキーワードを検索するとき、ユーザーによって意図...

vpsdime: 月額 7 ドル、新製品シリーズ - Windows VPS、4G メモリ/2 コア/50g SSD/2T トラフィック/ダラス データ センター

vpsdime は、新しい製品シリーズである Windows VPS を発売しました。構成は依然とし...

草の根電子商取引の皆さん、変革ラベルをお持ちですか?

2013年、小中米子は洛托に買収され、楚宇は印曼に買収された。一方で、インターネットに依存して成長し...