リアルタイムのサブスクリプション プッシュを実装するための Redis の 3 つの方法についての簡単な説明
20w のユーザーのプッシュを数秒で同時に完了するにはどうすればよいでしょうか?この記事では、Redis がリアルタイムのサブスクリプション プッシュを実装するための 3 つの方法、MQ、従来のスケジュールされたタスク、および Redis の SortSet キューを紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。
[関連する推奨事項: Redis ビデオ チュートリアル ]
少し前、私たちは会社のクーポン収集センター用のプロジェクトを開発しました。このプロジェクトは Redis を主要なテクノロジーとして実装しています。
まず、クーポン コレクション センター プロジェクトについて話しましょう。このプロジェクトは、JD.com アプリのクーポン コレクション センターと似ています。もちろん、写真は会社のものではなく、JD.com から取得したものです。 。 。
クーポン収集のためのサブスクリプション プッシュとは何ですか?
は、ユーザーがクーポンのプッシュ通知を購読していることを意味し、リマインダー情報は取得できる 1 分前にユーザーのアプリにプッシュされます。 このサブスクリプション機能、本来はメッセージセンターが実装する予定だったのですが、短期間では実装できないとのことでした。そこでクーポン担当の私がやってみました-.-!。具体的な計画は、特定のプッシュ時点に到達することであり、クーポン システムはメッセージ センターのプッシュ インターフェイスを呼び出して情報をプッシュします。 この機能のビジネス シナリオを分析してみましょう。同社には現在 6000W の登録ユーザーがいます。誰なのかは聞かないでください。 。 。たとえば、注文時に 20 元が即時に割引されるしきい値なしの割引クーポンがあれば、より多くの人がこのクーポンを手に入れるでしょうが、控えめに見積もっても 10 W と推定されますが、それが 10 W であるかどうかは判断できません。百万元。当初の目標は 200,000 人なので、この 200,000 件のプッシュ メッセージは 1 分で送信されます。また、1 人のユーザーが複数のクーポンを購読できます。したがって、このサブスクリプション機能には 2 つの顕著な問題があることがわかります。- プッシュの効果: プッシュが遅いと、ユーザーは通知が間に合わず、通知を逃したと不満を抱くでしょう。掴み始めるチャンス。
- プッシュ量大、誰もが手に入れたい人気クーポン!
オプション 1:
MQ の配信の遅延。 MQ はメッセージの遅延配信をサポートしていますが、スケールが 1 秒 5 秒 10 秒 30 秒 1 分と大きすぎるため、正確な時点の配信には使用できません。また、サブスクリプション実行後にユーザーがサブスクリプションをキャンセルした場合、送信された MQ メッセージを削除する操作は少し面倒で、短期間で実装するのは困難です。また、ユーザーはキャンセルしてから購読することもできますが、これにも重複排除の問題が伴います。したがって、MQ の計画は拒否されます。オプション 2:
従来のスケジュールされたタスク。これは比較的単純で、スケジュールされたタスクを使用するには、ユーザーのサブスクリプション リマインダー レコードをデータベースにロードし、現在プッシュできるレコードを選択します。しかし、よく当たる格言があります。実際のビジネスから切り離されたデザインは不正なものです。従来のスケジュールされたタスクが当社のビジネスに適しているかどうかを分析してみましょう!一般的にはそうではなく、同じです常に単独でのみ実行できます。 | |
通常は mysql またはその他の従来のデータベースであり、単一テーブル ストレージです | |
秒、分、時間、日をサポートしますが、通常はあまり速くありません |
以上がリアルタイムのサブスクリプション プッシュを実装するための Redis の 3 つの方法についての簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











1. [スタート]メニューを起動し、[cmd]と入力し、[コマンドプロンプト]を右クリックし、[管理者として実行]を選択します。 2. 次のコマンドを順番に入力します (注意してコピーして貼り付けてください): SCconfigwuauservstart=auto、Enter キーを押す SCconfigbitsstart=auto、Enter キーを押す SCconfigcryptsvcstart=auto、Enter キーを押す SCconfigtrustedinstallerstart=auto、Enter キーを押す SCconfigwuauservtype=share、Enter キーを押す netstopwuauserv 、enter netstopcryptS を押す

PHP 関数のボトルネックはパフォーマンスの低下につながります。これは、ボトルネック関数を特定し、パフォーマンス分析ツールを使用するという手順で解決できます。結果をキャッシュして再計算を減らします。タスクを並列処理して実行効率を向上させます。文字列の連結を最適化し、代わりに組み込み関数を使用します。カスタム関数の代わりに組み込み関数を使用します。

GolangAPI のキャッシュ戦略により、パフォーマンスが向上し、サーバーの負荷が軽減されます。一般的に使用される戦略は、LRU、LFU、FIFO、TTL です。最適化手法には、適切なキャッシュ ストレージの選択、階層型キャッシュ、無効化管理、監視とチューニングが含まれます。実際には、データベースからユーザー情報を取得する API を最適化するために LRU キャッシュが使用されます。それ以外の場合は、データベースからデータを取得した後にキャッシュを更新できます。

Erlang と Go にはパフォーマンスの違いがあります。 Erlang は同時実行性に優れていますが、Go はより高いスループットとより高速なネットワーク パフォーマンスを備えています。 Erlang は高い同時実行性を必要とするシステムに適しており、Go は高スループットと低遅延を必要とするシステムに適しています。

PHP 開発では、キャッシュ メカニズムにより、頻繁にアクセスされるデータがメモリまたはディスクに一時的に保存され、データベース アクセスの数が削減され、パフォーマンスが向上します。キャッシュの種類には主にメモリ、ファイル、データベース キャッシュが含まれます。キャッシュは、組み込み関数またはサードパーティのライブラリ (cache_get() や Memcache など) を使用して PHP に実装できます。一般的な実用的なアプリケーションには、データベース クエリ結果をキャッシュしてクエリ パフォーマンスを最適化したり、ページ出力をキャッシュしてレンダリングを高速化したりすることが含まれます。キャッシュ メカニズムにより、Web サイトの応答速度が効果的に向上し、ユーザー エクスペリエンスが向上し、サーバーの負荷が軽減されます。

Redis キャッシュを使用すると、PHP 配列ページングのパフォーマンスを大幅に最適化できます。これは、次の手順で実現できます。 Redis クライアントをインストールします。 Redisサーバーに接続します。キャッシュ データを作成し、データの各ページをキー「page:{page_number}」を持つ Redis ハッシュに保存します。キャッシュからデータを取得し、大規模な配列での高コストの操作を回避します。

まず、システム言語を簡体字中国語表示に設定して再起動する必要があります。もちろん、以前に表示言語を簡体字中国語に変更したことがある場合は、この手順をスキップできます。次に、レジストリ regedit.exe の操作を開始し、左側のナビゲーション バーまたは上部のアドレス バーで HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage に直接移動し、InstallLanguage キーの値と Default キーの値を 0804 に変更します (英語に変更する場合)。まずシステムの表示言語を en-us に設定し、システムを再起動してから、すべてを 0409 に変更します) この時点でシステムを再起動する必要があります。

はい、Navicat は Redis に接続できます。これにより、ユーザーはキーの管理、値の表示、コマンドの実行、アクティビティの監視、問題の診断が可能になります。 Redis に接続するには、Navicat で「Redis」接続タイプを選択し、サーバーの詳細を入力します。
