背景 分散アーキテクチャでは、一意のシリアル番号を生成することは、特にデータベースがシャーディングを使用する場合に、システムを設計するときによく発生する問題です。複数のシャーディング テーブルに分割されている場合、一意のシリアル番号をすばやく取得する方法がよく問題になります。 Ctrip のアカウント データベースを MySQL に移行するプロセス中に、Ctrip の既存の新規ユーザー登録量をサポートするために、ユーザー ID 生成スキームを再設計しました。 この記事では、Ctrip ユーザー ID ジェネレーターを実装し、サブライブラリとサブテーブルの一意の ID を設計するための新しいアイデアを提供することを目的としています。
2. 機能要件
3. 業界ソリューション さまざまなシナリオ、ニーズ、パフォーマンス要件に合わせて ID を生成する方法は多数あります。 一般的な方法は次のとおりです。 1. データベース全体で一意のデータベース増分を使用します。 利点: 明白で制御可能。 デメリット: 単一のデータベースと単一のテーブル、高いデータベース負荷。 2. UUID、生成された文字列は長さ = 32 の 16 進形式です。合計 16 バイト要素を持つバイト配列に変換されると、UUID は 128 ビットの数値になり、通常は 16 進数で表されます。 利点: データベースへの負荷が軽減されます。 デメリット: では、ソートはどうでしょうか? 時間連結を追加する UUID のバリエーションもありますが、ID が非常に長くなります。 3. Twitter は、ストレージ システムを MySQL から Cassandra に移行する過程で、独自のグローバルに一意な ID 生成サービスである Snowflake を開発しました。これは、Cassandra にはシーケンシャル ID 生成メカニズムがなかったためです。
利点: 高性能、低レイテンシ。独立したアプリケーション。時間順に並べます。 デメリット: 独立した開発と展開が必要です。 4. RedisがIDを生成する データベースを使用して ID を生成するパフォーマンスが十分でない場合は、Redis を使用して ID を生成してみることができます。これは主に、Redis がシングルスレッドであるという事実に依存しており、グローバルに一意の ID を生成するためにも使用できます。これは、Redis のアトミック操作 INCR と INCRBY を使用して実現できます。 より高いスループットを得るには、Redis クラスターを使用できます。クラスター内に 5 台の Redis サーバーがあるとします。各Redisの値はそれぞれ1、2、3、4、5に初期化でき、ステップの長さは5です。各Redisによって生成されるIDは次のとおりです。 答え: 1,6,11,16,21 B: 2,7,12,17,22 C: 3,8,13,18,23 4,9,14,19,24 (アメリカ) E: 5,10,15,20,25 毎日 0 から始まるシリアル番号を生成するには、Redis を使用する方が適しています。たとえば、注文番号 = 日付 + その日の自動増分番号。毎日 Redis でキーを生成し、INCR を使用してそれを蓄積することができます。 アドバンテージ: データベースから独立しており、柔軟性と利便性に優れ、パフォーマンスもデータベースよりも優れています。 数値 ID は自然にソートされるため、ページングやソートが必要な結果に役立ちます。 Redis クラスターを使用すると、単一障害点の問題も防ぐことができます。 欠点: システムで Redis が利用できない場合は、新しいコンポーネントを導入する必要があり、システムの複雑さが増します。 コーディングや設定の作業量が比較的大きく、複数環境の運用・保守が非常に面倒です。 最初に、プログラム インスタンスがロードされる Redis インスタンスが決定されると、将来的にそれを変更することは困難です。 5. フリッカーの解決策 MySQL 自体が auto_increment 操作をサポートしているため、この機能を使用してこの関数を実装すると考えるのは当然です。 Flicker は、MySQL の自己増分 ID メカニズム (auto_increment + replace into + MyISAM) を使用して、グローバル ID 生成ソリューションを解決します。 6. JD.com や Taobao などの電子商取引プラットフォームの注文番号を生成するなどの他のソリューションもあります。注文番号とユーザー ID にはビジネス上の違いがあるため、注文番号には次のような冗長なビジネス情報をできるだけ多く含める必要があります。 Didi: 時間 + 出発地番号 + ナンバープレート番号 タオバオ注文: タイムスタンプ + ユーザーID その他の電子商取引企業: タイムスタンプ + 注文チャネル + ユーザー ID。注文の最初のアイテムの ID を追加するものもあります。 ユーザー ID は、登録チャネルを含めて意味がシンプルで明確であり、できるだけ短くする必要があります。 4. 最終解決策 最終的に、ちらつきの解決策を最適化して改善することを選択しました。具体的な実装は、単一のテーブルを増分し、セグメント数をメモリにキャッシュすることです。 まず、次のようなテーブルを作成します。 シーケンスジェネレータテーブル ID スタブ 1 192.168.1.1 IDは自動的に増加し、スタブはサーバーのIPです 新しいデータベースは MySQL を使用するため、MySQL の独自の構文 replace を使用してレコードを更新し、一意の ID を取得します。次に例を示します。
次に、SELECT id FROM SEQUENCE_GENERATOR_TABLEWHERE stub = "192.168.1.1"; を使用します。それを取り戻すために。 これまでのところ、単一のデータベースでのみ ID を生成しました。高可用性の観点から、単一障害点の問題を解決する必要があります。 これが、このマシン IP フィールドが必要な理由です。これは、複数のサーバーが同時にデータを更新し、取得した ID に混乱が生じるのを防ぐためです。 したがって、サーバーが複数ある場合、表は次のようになります。 ID スタブ 5 192.168.1.1 2 192.168.1.2 3 192.168.1.3 4 192.168.1.4 各サーバーは自身のレコードのみを更新するため、単一行のレコードに対してシングルスレッド操作が保証されます。 このとき、各マシンはそれぞれ 5、2、3、4 の 4 つの ID を取得します。 これまでのところ、サーバーの分離とアトミック ID 取得の問題を解決したようですが、これは基本的にフリッカー ソリューションと同じです。 ただし、ソースを遡って考えると、原則として、ソリューションは依然としてデータベースの特性に依存します。 ID が生成されるたびにデータベースへのリクエストが必要となり、コストが非常に高くなります。これをさらに最適化し、この ID をシリアル番号ではなく番号セグメントとして使用して送信するようになりました。さらに、この数字セグメントの長さは 1000 または 10000 に設定できます。つまり、ID を何倍に拡大するかという問題です。 1 回のクエリ操作のオーバーヘッドで、1000 個のユーザー ID を DB からメモリに取得しました。 現在の問題は、同じサーバー上での高同時実行性の問題を解決し、重複や漏れなく全員が順番に番号を取得できるようにすることです。 簡単に言えば、この問題は、この数値セグメント内のオブジェクトの分離を維持することです。 AtomicLong は信頼できる方法です。 セグメント ID が初めて取得されるとき、セグメント ID は 1000 回拡張され、変数 atomic に割り当てられます。これはこのセグメントの最初の番号です。
そして、この数字セグメントの最後の数字である***idをメモリに保存します。
数値セグメントが形成されます。 このとき、番号を取る要求があるたびに、最後の番号に達したかどうかが判断されます。そうでない場合は、番号を受け取って立ち去ってください。
最後の数字に達すると、他のリクエストスレッドはブロックされ、最も早いスレッドが DB にアクセスして数字セグメントを取得し、数字セグメントの 2 つの値を更新します。 このソリューションは、コア コード ロジックが 20 行未満で、分散システムにおけるシリアル番号生成の問題を解決します。 ここで小さな問題があります。サーバーを再起動すると、番号がメモリにキャッシュされるため、一部のユーザー ID が無駄になります。したがって、頻繁にリリースされる可能性のあるアプリケーションでは、無駄を減らすために、数値セグメント増幅のステップサイズ n をできるだけ小さくするのが最適です。 練習した後は、ID を無駄にするよりもパフォーマンスの向上の方がはるかに重要です。 再度ハッキングを続けたい場合は、Spring または Servlet コンテキストの破棄イベントを監視し、送信されようとしているユーザー ID を保存し、次回の起動時にそれをメモリに再度取得することができます。 5. オンライン効果 5か月以上稼働しており、非常に安定しています。 SOA サービスの平均応答時間は 0.59 ミリ秒です。 クライアント呼び出しの平均応答時間は 2.52 ミリ秒です。 フローチャートを添付します: |
<<: Google Cloud Platform が GPU 価格を最大 36% 引き下げ
>>: 分散ストレージシステム VeSpace のアプリケーションシナリオの紹介
画像ソース: https://pixabay.com/images/id-4343635/テクノロジ...
ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービス金融業界は、ユーザーの注...
誰もが、一夜にして成し遂げられることはなく、完璧なものなど存在しないことを知っています。時代の変化と...
オフライン展示会の固定観念を打ち破り、移動の手間を省き、疫病下での安全リスクを回避する、新しいオンラ...
適切なウェブサイトのレイアウトは、キーワードで良いランキングを獲得するための基礎となります。また、ユ...
Weibo は Sina にとって独自の道となる可能性があったが、Sina は既存のメンタルモデルを...
「ウェブサイトで活用すべき Google アナリティクスのヒント 11 選」という記事では、目標設定...
10年以上前、ソフトバンクグループに大量の事業企画が殺到した。最終候補に挙がったアリババとタオバオは...
2018年最もホットなプロジェクト:テレマーケティングロボットがあなたの参加を待っています現在、広東...
webhostingbuzz は 11 周年を記念して、全製品を 25% 割引でご提供します。この価...
ドバイのホストプロバイダーであるHostsailor(正式登録:A224/03/14/8150、完全...
多くのウェブマスターの友人は、「外部リンクが多すぎると、ウェブサイトのランクが下がるのでしょうか?」...
以前、北京で開催されたインタラクティブ体験デーで、私は新浪のプロダクトマネージャー、李啓明氏の「より...
マシュー効果とは何でしょうか?それは単純とも複雑とも言えます。良くなれば良くなるほど、チェックは悪く...
セキュリティ管理から人員配置まで、ハイブリッド クラウド サービス モデルは、現在成長段階にある組織...