検索
ホームページデータベースRedisRedisの分散型電流制限機構の実装方法

インターネット アプリケーションの開発に伴い、インターネット企業にとって高い同時アクセスが非常に重要な問題になっています。システムの安定性を確保するには、悪意のある攻撃や過剰なアクセスによるシステムクラッシュを防ぐためにアクセスを制限する必要があります。電流制限メカニズムはインターネット アプリケーションで広く使用されており、人気のあるキャッシュ データベースとして Redis も分散型電流制限ソリューションを提供します。

Redis の電流制限メカニズムには、主に次の 2 つの実装方法があります:

1. トークン バケット アルゴリズムに基づく電流制限

トークン バケット アルゴリズムは、一般的に使用されるアルゴリズムです。ストリーミング アルゴリズムの 1 つである Redis は、トークン バケット アルゴリズムに基づいた電流制限ソリューションを提供します。このソリューションの実装は、主に Redis のオーダード セット (zset) と Lua スクリプトに基づいています。

トークン バケット アルゴリズムの原理は、トークンが一定のレートで投入される固定容量のバケットです。各リクエストは、処理される前にバケットからトークンを取得する必要があります。バケット内にトークンがない場合、リクエストは拒否されます。

Redis では、順序付きセット (zset) を使用してトークン バケットを構築できます。順序付きセット内の各要素はトークンを表し、そのスコアはトークンの到着時間を表し、値は任意の値にすることができます。トークンの取得操作の実装にはLuaスクリプトを使用します。具体的な実装コードは以下のとおりです。

-- 获取令牌
local function acquire_token(key, rate, capacity, now)
  local current_capacity = redis.call("zcount", key, "-inf", "+inf")
  local delta_time = 1000 / rate
  local expected_token = math.floor((now - delta_time * capacity) / delta_time)
  local available_token = math.min(expected_token - current_capacity, capacity)
  if available_token > 0 then
    local members = {}
    for i = 1, available_token do
      members[i] = now
    end
    redis.call("zadd", key, unpack(members))
  end

  local current_time = now
  local stop_time = current_time + 1000
  local expire_time = stop_time - delta_time * (available_token - 1)
  local result = redis.call("zrangebyscore", key, "-inf", expire_time)
  if #result > 0 then
    redis.call("zrem", key, unpack(result))
    return 1
  end

  return 0
end

-- 调用获取令牌操作
local result = acquire_token(KEYS[1], ARGV[1], ARGV[2], ARGV[3])
return result

このうち、KEYS[1]は電流制限キー、ARGV[1]はトークン投入率、ARGV[2]はバケットを表します。容量、ARGV[3] は現在の時刻を表します。

2. ファネル アルゴリズムに基づく電流制限

ファネル アルゴリズムも一般的に使用される電流制限アルゴリズムです。その原理はファネルです。リクエストは水のようにファネルに流れ込みます。ファネル アルゴリズムがいっぱいになるとオーバーフローします。 Redis では、順序付きセット (zset) と Lua スクリプトを使用してファネル アルゴリズムを実装することもできます。

ファネル アルゴリズムは、最後のリクエストの時刻とバケットの現在の容量を記録するためにファネル オブジェクトを維持する必要があります。新しいリクエストが届くと、アルゴリズムは現在の時間と最後のリクエスト時間の差に基づいてファネルの容量の増加を計算します。容量がバケットの最大容量より小さい場合、リクエストの通過が許可され、容量が減ります。それ以外の場合、リクエストは拒否されます。

具体的な実装コードは以下のとおりです。

-- 获取令牌
local function acquire_token(key, rate, capacity, now)
  local current_capacity = redis.call("hget", key, "capacity")
  local last_time = redis.call("hget", key, "last_time")

  if current_capacity == redis.error_reply or current_capacity == ngx.null then
    current_capacity = capacity
    redis.call("hset", key, "capacity", current_capacity)
  else
    current_capacity = tonumber(current_capacity)
  end

  if last_time == redis.error_reply or last_time == ngx.null then
    last_time = now
    redis.call("hset", key, "last_time", last_time)
  else
    last_time = tonumber(last_time)
  end

  local delta_time = now - last_time
  local expected_capacity = delta_time * rate / 1000 + current_capacity
  local actual_capacity = math.min(expected_capacity, capacity)

  if actual_capacity >= 1 then
    redis.call("hset", key, "capacity", actual_capacity - 1)
    redis.call("hset", key, "last_time", now)
    return 1
  end

  return 0
end

-- 调用获取令牌操作
local result = acquire_token(KEYS[1], ARGV[1], ARGV[2], ARGV[3])
return result

このうち、KEYS[1]は電流制限Key、ARGV[1]はファンネルの加水率、ARGV[2]を表します。 ] はファンネルの容量を表し、ARGV [3] は現在時間を表します。

概要

Redis が提供する分散型電流制限メカニズムは、同時アクセスを効果的に制御し、システムの安定性を確保できます。ビジネス ニーズに応じて電流制限アルゴリズムとしてトークン バケット アルゴリズムまたはファネル アルゴリズムを選択し、Redis のオーダード セット (zset) と Lua スクリプトを通じて実装できます。電流制限メカニズムを適用する場合、ユーザー エクスペリエンスへの悪影響を回避するために、特定のビジネス シナリオとトラフィック特性に基づいてアルゴリズム パラメーターを合理的に構成する必要があることに注意してください。

以上がRedisの分散型電流制限機構の実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Redis:SQLを超えて-NOSQLの視点Redis:SQLを超えて-NOSQLの視点May 08, 2025 am 12:25 AM

Redisは、高性能と柔軟性のためにSQLデータベースを超えています。 1)Redisは、メモリストレージを介して非常に速い読み取りおよび書き込み速度を実現します。 2)複雑なデータ処理に適したリストやコレクションなど、さまざまなデータ構造をサポートしています。 3)シングルスレッドモデルは開発を簡素化しますが、高い並行性はボトルネックになる可能性があります。

Redis:従来のデータベースサーバーとの比較Redis:従来のデータベースサーバーとの比較May 07, 2025 am 12:09 AM

Redisは、並行性が高く、遅延の低いシナリオの従来のデータベースよりも優れていますが、複雑なクエリやトランザクション処理には適していません。 1.Redisは、メモリストレージ、高速読み取り速度、および高い並行性と低遅延の要件に適しています。 2.従来のデータベースは、ディスクに基づいており、複雑なクエリとトランザクション処理をサポートし、データの一貫性と永続性が強い。 3. Redisは、従来のデータベースのサプリメントまたは代替品として適していますが、特定のビジネスニーズに応じて選択する必要があります。

Redis:強力なメモリデータストアの紹介Redis:強力なメモリデータストアの紹介May 06, 2025 am 12:08 AM

redisisahigh-performancein-memorydatastructurturturestorettorethatedcelsinsinsinsversility.1)itsupportsvariousdatastructureslikestrings、lists、andsets.2)redisisaninmorydatabasewithpersistenceoptions、daturing datasafety.3)

Redisは主にデータベースですか?Redisは主にデータベースですか?May 05, 2025 am 12:07 AM

Redisは主にデータベースですが、単なるデータベース以上のものです。 1.データベースとして、Redisは持続性をサポートし、高性能のニーズに適しています。 2。キャッシュとして、Redisはアプリケーションの応答速度を改善します。 3。メッセージブローカーとして、Redisはリアルタイム通信に適したPublish-Subscribeモードをサポートしています。

Redis:データベース、サーバー、または他の何か?Redis:データベース、サーバー、または他の何か?May 04, 2025 am 12:08 AM

redisisamultifaCetedTooltoToolvesSasadatabase、server、andmore。

Redis:その目的と主要なアプリケーションを発表しますRedis:その目的と主要なアプリケーションを発表しますMay 03, 2025 am 12:11 AM

Redisisanopen-Source、In-MemoryDatastructurestoreStoreSadatabase、Cache、AndmessageBroker、ExcellingInspeedandversatility.ItisisWidely-susederCaching、Real-Timeanalytics、Session Management、AndleaderboardsdueTotutsuptorututrututrututruturturturturturturesturesaddataacys

Redis:キー価値データストアのガイドRedis:キー価値データストアのガイドMay 02, 2025 am 12:10 AM

Redisは、データベース、キャッシュ、メッセージブローカーとして使用されるオープンソースメモリデータ構造ストレージであり、高速応答と高い並行性が必要なシナリオに適しています。 1.Redisはメモリを使用してデータを保存し、マイクロ秒の読み取り速度と書き込み速度を提供します。 2.文字列、リスト、コレクションなどのさまざまなデータ構造をサポートします。3。Redisは、RDBおよびAOFメカニズムを介してデータの持続性を実現します。 4.シングルスレッドモデルと多重化テクノロジーを使用して、リクエストを効率的に処理します。 5.パフォーマンス最適化戦略には、LRUアルゴリズムとクラスターモードが含まれます。

Redis:キャッシュ、セッション管理などRedis:キャッシュ、セッション管理などMay 01, 2025 am 12:03 AM

Redisの関数には、主にキャッシュ、セッション管理、その他の機能が含まれます。1)キャッシュ関数はメモリを介してデータを保存して読み取り速度を向上させ、eコマースWebサイトなどの高周波アクセスシナリオに適しています。 2)セッション管理関数は、分散システムでセッションデータを共有し、有効期限のあるメカニズムを通じて自動的にクレンジングします。 3)リアルタイムメッセージプッシュおよびマルチスレッドシステムおよびその他のシナリオに適した、パブリッシュサブスクライブモード、分散ロック、カウンターなどのその他の機能。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール