環境: 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) を生成できます。デフォルトのバイト割り当て方法は上記のとおりです。
上記のパラメータはSpringを通じてカスタマイズできます。キャッシュされたUidジェネレータRingBuffer は円形配列であり、配列の各要素がスロットになります。デフォルトでは、RingBuffer の容量は、Snowflake アルゴリズムのシーケンスの最大値、つまり 2^N です。 boostPower 構成を通じて容量を拡張し、RingBuffer の読み取りおよび書き込みスループットを向上させることができます。 テール ポインターとカーソル ポインターは、円形配列のスロットの読み取りと書き込みに使用されます。
CachedUidGenerator はデュアル リング バッファを使用します。Uid-RingBuffer は Uid を保存するために使用され、Flag-RingBuffer は Uid ステータス (埋められるかどうか、消費できるかどうか) を保存するために使用されます。 配列要素はメモリ内に連続的に割り当てられるため、CPU キャッシュを最大限に活用してパフォーマンスを向上させることができます。しかし、それは「偽りの共有」の問題も引き起こすでしょう。このため、Tail、Cursor ポインター、Flag-RingBuffer では CacheLine パディング方式が使用されます。 リングバッファ充填時間
上記はBaiduの公式紹介です。次に、これを Springboot プロジェクトに統合します。 UIDGenerator ダウンロードuid-generatorを次のアドレスからダウンロードしてください UIDGenerator 環境設定テーブルを作成
そのプロジェクト内のmapper.xmlファイルを、WorkerNodeEntity、WorkerNodeDAOに対応する自分のプロジェクトにコピーします。 DisposableWorkerIdAssigner が独自のプロジェクトにコピーされます。 DisposableWorkerIdAssigner は主に、注入された DAO を変更します。ここでは、デフォルトの DAO 関連の設定を変更する必要があるためです。 プロジェクト構成頼る
mybatisの設定
マッパー ファイル内の名前空間と対応するドメインを独自のパスに変更します。 UIDGenerator の設定
ご了承ください DisposableWorkerIdAssigner は Baidu によって提供されるものではなく、独自のプロジェクトにコピーされます。
これですべての設定が完了しました。 テスト
完了!!! |
<<: 2020年、わが国のクラウドコンピューティング市場の規模は1,781億元に達し、成長率は33.6%でした。
>>: 面接で必ず聞かれるJVMランタイムデータ領域について理解していますか?
50vm は独立サーバーを推進しています。鎮江電信と貴州電信から選択できます。デュアルチャネル L5...
多くのウェブマスターの友人、特に初心者の友人は、ウェブサイトの最適化の初期段階で必然的にさまざまなこ...
インターネットの波の中で、プロのウェブマスターがどれだけ生き残っているかはわかりません。記事の最初の...
Chicagogovps のブラック フライデー プロモーションは部分的にリリースされており、仮想ホ...
検索エンジン最適化の継続的な発展により、インターネット上のさまざまな業界、企業、個人などが検索エンジ...
米国の市場調査会社ComScoreは本日、「vCE Charter」に関するさらなる調査データを公開...
月収10万元の起業の夢を実現するミニプログラム起業支援プランテンプレートを使用して Web サイトを...
Olinkcloud は中国が運営するホスティング ブランドであり、旧ブランド diahosting...
FinOps (クラウド財務運用) チームを作成していない多くの企業は、コストの管理と報告に苦労し、...
ウェブマスターとして、Baidu は私たちに大きな影響を与えています。Baidu ランキングが高けれ...
Baidu は、ユーザー エクスペリエンスを維持するための実際の対策となることを目指した記事「ザクロ...
今年の夏は気温が非常に高く、北部の沿岸都市大連でも秋に入ってから気温が33度を記録した。気温がどれだ...
2012 年、Red Hat はオープンソースの Linux ソフトウェアから始まり、年間収益が 1...
Cloudsilkは長年にわたり米国サンノゼデータセンターでVPSを提供しており、その中でもChin...
Weiboといえば、まず思い浮かぶのはSina Weiboです。Sina Weiboといえば、ヤオ・...