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ランタイムデータ領域について理解していますか?

推薦する

体験投稿: 地域アプリまたはWeChatパブリックアカウントのプロモーションに関する考察

地域プロモーションは、オフラインプロモーションとオンラインオペレーションを含む地上プロモーションとも...

SEOの技術的基盤の限界を取り除きたいなら、戦略だけが広い視野を与えてくれる。

SEOは大変な仕事だと言う人は多い。毎日、記事を書いて外部リンクを貼るだけ。IT業界の出稼ぎ労働者み...

プログラマーが人生を無駄にするいくつかの方法

プログラマーは自分の人生を大切にし、有用で有意義なことをするべきです。役に立つことをするには 2 つ...

本当のWeiboマーケティングの復活(第2部)

1.4 本当に成功したマイクロブログとはどのようなマイクロブログでしょうか?リポスト数が多いというこ...

オンラインストア情報型ウェブサイトプロモーション体験共有

数年前、ジャック・マーは「電子商取引をやらないと後悔する」と言いましたが、多くの個人ウェブマスターは...

digitalvirt はどうですか? 「US BGP Line VPS」のレビュー

digitalvirt はどうですか? digitalvirt のロサンゼルス BGP ライン VP...

どのブランドのワールドカップマーケティングキャンペーンが最も人気がありますか?

最近最もホットな話題は、間違いなくカタールワールドカップです。世界で最も商業的に価値のあるスポーツイ...

プロメテウス 16 周年記念 - 512M メモリ xen/四半期あたり 16 USD

ご存知のとおり、プロメテウスはLEBで確実に1位にランクされています。その安定性と高性能は誰もが知っ...

VDIとIDVは単なる文字の組み合わせではありません

コンピュータ仮想技術の継続的な成熟と仮想技術のより現実的な運用により、クラウド教室は広く普及し、小中...

他の人の経験から学ぶ: リンクベイトの実装方法

『詩経』には「他山の石で玉を磨く」という慣用句がある。元々の意味は、他山の石を磨くことで美しい玉に変...

rackhost-$3.5/10g ポート/無制限トラフィック/KVM/512M メモリ VPS

Rackhostはホストキャットに2回登場しました。2002年から運営しているこのホスティング業者(...

Baidu の製品バックリンクを放棄する 2 つの理由

2012 年、Baidu のアルゴリズム更新は非常に頻繁に行われ、更新の規模も比較的大きかった。更新...

映画サイトを立ち上げる前に知っておくべき3つのSEOテクニック

映画サイトで働いたことがある友人なら、映画サイトの競争が非常に激しいことを知っているはずです。今日で...