노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

青灯夜游
풀어 주다: 2023-01-17 19:48:31
앞으로
2167명이 탐색했습니다.

메시지 대기열이란 무엇인가요? 다음 문서에서는 메시지 대기열의 기본 개념을 안내하고 노드에서 메시지 대기열을 사용하는 방법을 소개합니다. 도움이 되기를 바랍니다.

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

1. 메시지 큐

메시지 큐란 무엇입니까

메시지 큐는 메시지 전송 과정에서 메시지를 저장하는 컨테이너입니다. 먼저)

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

메시지는 전송해야 하는 데이터를 나타내며 텍스트, 문자열 또는 개체 및 기타 정보일 수 있습니다.消息指的是需要传输的数据,可以是一些文本,字符串,或者是对象等信息。

消息队列则是两个应用间的通信服务,消息的产生者将数据存放到消息队列中就可以立即返回,不需要等待消息的接收者应答。即:生产者保证数据插入队列,谁来取这条消息不需要管。消息的接收者则只专注于接受消息并处理。【相关教程推荐:nodejs视频教程编程教学

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

消息队列能做什么

  • 解耦上面介绍了,消息队列将消息的生产者和消息的接收者分开,彼此都不受影响。

  • 异步异步就是为了减少请求的响应时间,消息的生产者只需要处理简单的逻辑,并将数据放到消息队列中即可返回,复杂的逻辑,比如:数据库操作,IO操作由消息的接收者处理。

  • 削峰消息队列应用在服务时,能将瞬时大量涌入的请求信息保存到消息队列中,并立即返回。再由消息的接收者根据数据处理请求。

  • 应用场景游戏活动,秒杀活动,下单等会造成瞬时流量暴增的应用。

2.消息队列的概念

介绍完消息队列的基本信息,在开发消息队列之前先介绍一下消息队列的一些基本概念~

消息的生产者(producer)与消费者(customer)

上文提到的生产者消费者,提供的是

链接,通道与队列

  • 链接(connection):表示服务程序与消息队列之间的一条链接。一个服务程序可以创建多条链接

  • 通道(channel):消息队列链接之间的一个通,一个链接可以有多个通道

  • 队列(queue):消息队列中存放数据的队列,一个消息队列服务可以有多个队列。

总结一下,链接,通道队列之间的关系是这样的

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

交换机(exchange)

消息队列发送消息必须要有一个交换机,如果没有指定则用的是默认的交换机。交换机的作用就是将消息才推到对应的队列中。消息队列中一共有4种交换机

  • Direct: 指定队列模式,消息来了,只发给指定的Queue,其他Queue都收不到。

  • fanout: 广播模式,消息来了,就会发送给所有的队列。

  • topic: 模糊匹配模式,通过模糊匹配的方式进行相应转发。

  • header: 与Direct模式类似。

3.node使用rabbitMQ

安装rabbitMQ

  • 安装rabbitMQ可以通过官网上进行下载安装,传送门
  • MAC可以直接用brew命令安装
    brew install rabbitmq
    로그인 후 복사
  • 安装完成后启动rabbitmq服务

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

然后再本地中访问 http://localhost:15672/ 就可以看到rabbitmq服务的后台。初始的账号密码均为guest

메시지 대기열은 두 애플리케이션 간의 통신 서비스입니다. 메시지의 생성기는 메시지< 코드를 기다리지 않고 메시지 대기열에 데이터를 저장한 후 즉시 반환할 수 있습니다. >수신자가 응답합니다. 즉, Producer는 데이터가 대기열에 삽입되도록 하며 누가 메시지를 받는지는 중요하지 않습니다. 메시지의 수신자는 메시지 수신 및 처리에만 집중합니다. [권장 관련 튜토리얼: nodejs 동영상 튜토리얼, 프로그래밍 교육

노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사

메시지 큐는 무엇을 할 수 있나요

  • Decoupling 위에서 소개한 것처럼 메시지 큐는 생산자와 생산자를 결합합니다. 메시지의 수신자는 분리되어 있으며 서로 영향을 받지 않습니다.
  • Asynchronous 비동기식은 요청의 응답 시간을 줄이는 것입니다. 메시지 생성자는 간단한 논리만 처리하고 반환할 데이터를 메시지 대기열에 넣으면 됩니다. IO 작업은 메시지 수신자에 의해 처리됩니다.
  • Peak Shaving 메시지 큐 애플리케이션이 서비스 중일 때 순간적으로 유입되는 요청 정보를 메시지 큐에 저장하고 즉시 반환할 수 있습니다. 그런 다음 데이터를 기반으로 메시지 수신자가 요청을 처리합니다.
  • 응용 시나리오 게임 활동, 깜짝 세일 활동, 주문 등 순간적인 트래픽 급증을 일으킬 수 있는 응용 프로그램입니다.

2. 메시지 큐의 개념메시지 큐의 기본 정보를 소개한 후, 메시지를 개발하기 전에 메시지 큐에 대해 소개하겠습니다. 몇 가지 기본 개념~메시지의 생산자와 소비자위에 언급된Producerconsumer는 링크로 제공됩니다. 채널 및 대기열
  • 링크(연결): 서비스 프로그램과 메시지 대기열 간의 링크를 나타냅니다. 서비스 프로그램은 여러 링크를 생성할 수 있습니다.
  • 채널(채널): 메시지 대기열 링크 사이의 채널 링크에는 여러 채널이 있을 수 있습니다.
  • 큐(queue): 메시지 큐에 데이터를 저장하는 큐입니다. 메시지 큐 서비스는 여러 개의 큐를 가질 수 있습니다.
결론적으로 링크와 채널 큐의 관계는 이렇습니다노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사스위치(교환)Message Queue메시지를 보낼 때 스위치가 있어야 합니다. 지정하지 않으면 기본 스위치가 사용됩니다. 스위치의 역할은 해당 대기열에 메시지를 푸시하는 것입니다. 메시지 대기열에는 총 4가지 유형의 스위치가 있습니다
  • 직접: 메시지가 오면 지정된 대기열로만 전송되고 다른 대기열에서는 메시지가 수신되지 않습니다. .
  • fanout: 방송 모드, 메시지가 오면 모든 대기열로 전송됩니다.
  • 주제: 퍼지 매칭 모드, 퍼지 매칭을 통해 그에 따라 전달됩니다.
  • 헤더: 다이렉트 모드와 유사합니다.

3.node는 RabbitMQ를 사용합니다rabbitMQ 설치
  • rabbitMQ 설치는 다음을 통해 수행할 수 있습니다. 공식 웹사이트 다운로드 및 설치,포털
  • MAC Brew 명령을 사용하여
    /** 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(); })();
    로그인 후 복사
    로그인 후 복사
    를 직접 설치할 수 있습니다.
  • 설치가 완료된 후 Rabbitmq 서비스를 시작하세요.
노드에서 메시지 큐를 사용하는 방법을 간략하게 분석한 기사그런 다음 로컬에서 http://localhost:15672/를 방문하여 Rabbitmq 서비스의 배경을 확인하세요. 초기 계정 비밀번호는guestnode 프로젝트 설치 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:juejin.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!