ノードでメッセージキューを使用する方法を簡単に分析した記事
メッセージキューとは何ですか?次の記事では、メッセージ キューの基本概念を説明し、ノードでメッセージ キューを使用する方法を紹介します。
#1. メッセージ キュー
##メッセージ キューとは
メッセージ キューは、メッセージ送信プロセス中にメッセージを保存するコンテナであり、本質的にはキュー (先入れ先出し)#Message
Message Queue
プロデューサ は、メッセージを待たずに、メッセージ キューにデータを格納した後、すぐに戻ることができます。
受信機が応答します。つまり、
Producer はデータがキューに挿入されることを保証し、誰がこのメッセージを受け取るかについて心配する必要はありません。メッセージの
受信者 は、メッセージの受信と処理のみに重点を置いています。 [関連チュートリアルの推奨事項:
nodejs ビデオ チュートリアル 、
プログラミング教育 ]
- 分離
- 上で紹介したように、メッセージ キューはメッセージ プロデューサーとメッセージ レシーバーを分離し、どちらも他方の影響を受けません。 。
- 非同期とは、リクエストの応答時間を短縮することです。メッセージのプロデューサーは、単純なロジックを処理し、データをメッセージ キューに入れて返すだけで済みます。 . データベース操作、IO 操作などの複雑なロジックは、
メッセージの受信者 によって処理されます。
ピークシェービング - メッセージ キュー アプリケーションは、処理中に、瞬間的に流入するリクエスト情報をメッセージ キューに保存し、すぐに返すことができます。その後、リクエストはメッセージの受信者によってデータに基づいて処理されます。
- ゲーム アクティビティ、フラッシュ セール アクティビティ、注文などのアプリケーションでは、トラフィックが突然増加します。
メッセージ キューの基本情報を紹介した後、開発する前にメッセージ キューの一部を紹介しましょう。メッセージ キュー。基本概念~
メッセージのプロデューサとコンシューマ上記のプロデューサ
とコンシューマ
Link (接続): サービス プログラム間のリンクを表します。そしてメッセージキュー。
- サービス プログラムは複数のリンクを作成できます
- 。
チャネル: メッセージ キュー リンク間のチャネル。
1 つのリンクに複数のチャネルを含めることができます。 キュー (キュー): メッセージ キューにデータを保存するキュー。メッセージ キュー サービスは複数のキューを持つことができます。
- #要約すると、リンクとチャネル キューの関係は次のようになります。
Exchange )
メッセージ キューメッセージを送信するときは、スイッチが必要です。指定しない場合は、デフォルトのスイッチが使用されます。スイッチの役割は、メッセージを対応するキューにプッシュすることです。メッセージキューには全部で4種類のスイッチがあります
Direct: キューモードを指定 メッセージが来ると指定したQueueのみに送信し、それ以外のQueueには送信します受け取りません。
- fanout: ブロードキャスト モード。メッセージが到着すると、すべてのキューに送信されます。
- トピック: ファジー マッチング モード、ファジー マッチングによる対応する転送。
- header: ダイレクト モードに似ています。
- #3.node は RabbitMQ を使用します
#RabbitMQ のインストールは、公式 Web サイトからダウンロードしてインストールできます。
PortalMAC では、brew コマンドを直接使用して、brew install rabbitmq
##node プロジェクトのインストール amqplib
amqplib是node中使用消息队列的一套工具,可以让我们快速地使用消息队列
地址:https://www.npmjs.com/package/amqplib
创建生产者
/** product.js 消费者 */ const amqplib = require('amqplib'); const config = require('./config'); const { connectUrl } = config; (async () => { const connection = await amqplib.connect(connectUrl); const channel = await connection.createChannel(); const exchangeName = 'testExchange'; const key = 'testQueue'; const sendMsg = 'hello rabbitmq'; // 知道交换机类型 await channel.assertExchange(exchangeName, 'fanout', { durable: true, }); // 指定一个队列 await channel.assertQueue(key); for (let i = 0; i < 100; i++) { channel.publish(exchangeName, key, Buffer.from(`${sendMsg} ${i}`)); } await channel.close(); await connection.close(); })();
运行后在后台可以看到新增了一个有100条消息的队列
创建消费者
/** customer.js 消费者 */ const amqplib = require('amqplib'); const config = require('./config'); const { connectUrl } = config; (async () => { let connection = await amqplib.connect(connectUrl); const exchangeName = 'testExchange'; const key = 'testQueue'; // 创建两个通道 const channel1 = await connection.createChannel(); const channel2 = await connection.createChannel(); // 指定一个交换机 await channel1.assertExchange(exchangeName, 'fanout', { durable: true, }); // 指定一个队列 await channel1.assertQueue(key); await channel1.bindQueue(key, exchangeName, key); channel1.consume(key, (msg) => { console.log('channel 1', msg.content.toString()); }); await channel2.assertExchange(exchangeName, 'fanout', { durable: true, }); await channel2.assertQueue(key); await channel2.bindQueue(key, exchangeName, key); channel2.consume(key, (msg) => { console.log('channel 2', msg.content.toString()); }); })();
执行后可以看到,两个通道可以同时工作接收消息
更多node相关知识,请访问:nodejs 教程!
以上がノードでメッセージキューを使用する方法を簡単に分析した記事の詳細内容です。詳細については、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)

ホットトピック

Java Websocket 開発実践: メッセージキュー機能の実装方法 はじめに: インターネットの急速な発展に伴い、リアルタイム通信の重要性がますます高まっています。多くの Web アプリケーションでは、リアルタイム メッセージングによるリアルタイムの更新と通知機能が必要です。 JavaWebsocket は、Web アプリケーションでのリアルタイム通信を可能にするテクノロジーです。この記事では、JavaWebsocket を使用してメッセージ キュー機能を実装する方法と、具体的なコード例を紹介します。メッセージキューの基本概念

FastAPI での非同期タスク処理にメッセージ キューを使用する方法 はじめに: Web アプリケーションでは、電子メールの送信やレポートの生成など、時間のかかるタスクを処理する必要があることがよくあります。これらのタスクが同期の要求と応答のプロセスに配置されると、ユーザーは長時間待機する必要があり、ユーザー エクスペリエンスとサーバーの応答速度が低下します。この問題を解決するには、非同期タスク処理にメッセージ キューを使用します。この記事では、メッセージ キューを使用して FastAPI フレームワークで非同期タスクを処理する方法を紹介します。

ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

Golang 開発: NATS を使用して信頼性の高いメッセージ キューを構築するには、特定のコード サンプルが必要です はじめに: 最新の分散システムでは、メッセージ キューは、非同期通信の処理、システム コンポーネントの分離、および信頼性の高いメッセージ配信の実現に使用される重要なコンポーネントです。この記事では、Golang プログラミング言語と NATS (正式名は「High Performance Reliable Message System」) を使用して効率的で信頼性の高いメッセージ キューを構築する方法を紹介し、具体的なコード例を示します。 NATSとは何ですか? NATS は、軽量のオープンソース メッセージング システムです。

認証は、Web アプリケーションの最も重要な部分の 1 つです。このチュートリアルでは、トークンベースの認証システムと、それが従来のログイン システムとどのように異なるかについて説明します。このチュートリアルを終えると、Angular と Node.js で書かれた完全に動作するデモが表示されます。従来の認証システム トークンベースの認証システムに進む前に、従来の認証システムを見てみましょう。ユーザーはログイン フォームにユーザー名とパスワードを入力し、[ログイン] をクリックします。リクエストを行った後、データベースにクエリを実行してバックエンドでユーザーを認証します。リクエストが有効な場合、データベースから取得したユーザー情報を使用してセッションが作成され、セッション情報が応答ヘッダーで返され、セッション ID がブラウザに保存されます。対象となるアプリケーションへのアクセスを提供します。

Linux スクリプト操作を使用して Java でメッセージ キューを実装する方法には、特定のコード サンプルが必要です。メッセージ キューは、異なるプロセス間でデータを転送するために使用される一般的な通信メカニズムです。 Java では、Linux スクリプト操作を使用してメッセージ キューを実装できるため、キューとの間でメッセージを簡単に送受信できるようになります。この記事では、Java および Linux スクリプトを使用してメッセージ キューを実装する方法を詳しく説明し、具体的なコード例を示します。 Java と Lin を始めるには

C# 開発で分散トランザクションとメッセージ キューを処理する方法 はじめに: 今日の分散システムでは、トランザクションとメッセージ キューは非常に重要なコンポーネントです。分散トランザクションとメッセージ キューは、データの一貫性とシステムの分離を処理する上で重要な役割を果たします。この記事では、C# 開発における分散トランザクションとメッセージ キューの処理方法と、具体的なコード例を紹介します。 1. 分散トランザクション 分散トランザクションとは、複数のデータベースまたはサービスにまたがるトランザクションを指します。分散システムでは、データの一貫性をどのように確保するかが大きな課題となっています。ここでは2種類の

メッセージ キューでの Redis の素晴らしい使用法 メッセージ キューは、アプリケーション間で非同期メッセージを配信するために使用される一般的な分離されたアーキテクチャです。メッセージをキューに送信することにより、送信者は受信者からの応答を待たずに他のタスクの実行を続けることができます。そして、受信者はキューからメッセージを取得し、適切なタイミングでそれを処理できます。 Redis は、高いパフォーマンスと永続ストレージ機能を備えた、一般的に使用されているオープンソースのメモリ内データベースです。メッセージ キューでは、Redis の複数のデータ構造と優れたパフォーマンスにより理想的な選択肢となります。
