当前位置: 首页 > news >正文

网站生成软件app制作成品网站seo

网站生成软件app制作,成品网站seo,东莞建设企业网站,做网站的目录 一、MQ概述 二、MQ的优势和劣势 三、常见的MQ产品 RabbitMQ使用步骤 第一步:确保rabbitmq启动并且可以访问15672 第二步:导入依赖 第三步:配置 auto自动确认 manual手工确认(推荐使用!可以防止消息丢失&a…

目录

一、MQ概述

二、MQ的优势和劣势

 三、常见的MQ产品

RabbitMQ使用步骤

第一步:确保rabbitmq启动并且可以访问15672

第二步:导入依赖

第三步:配置

auto自动确认

manual手工确认(推荐使用!可以防止消息丢失)

第四步:编写生产者和消费者


一、MQ概述

  MQ 全称是Message Queue(消息队列),是在消息传输过程中保存消息的容器,多用于分布式         系统之间进行通信。

二、MQ的优势和劣势

   优势

  • 应用解耦  :  系统的耦合性越高,容错性就越低,可维护性就越低,使用MQ 使得应用间解耦, 提升容错性和可维护性。

  • 异步提速 :  提升用户体验和系统吞吐量(单位时间内处理请求的数目)。

  • 削锋填谷 :  使用了MQ之后,限制消费消息的速度为2000,这样一来,高峰期产生的数据势必 会被积压在 MQ中,高峰 就被“”掉了。但是因为消息积压,在高峰期过后的一段时间内,消费消息的速度还是会维持在1000,直到消费完积压的消息,这就叫做 填谷”。使用MQ后,可以提高系统稳定性。

  劣势

  • 系统的可用性降低  :  引入的外部依赖越多,系统稳定性越差,一旦MQ宕机,会对业务系统造  成影响。如何保证MQ的高可用?

  • 系统复杂度提高  :   MQ的加入增加了系统的复杂度,以前是系统间同步的远程调用,现在是      通过MQ进行一部调用,怎么处理消息丢失情况?如何保证消息传递的顺序性。

  • 一致性问题  :  A系统发给BCD系统,若其中一个系统处理数据失败,如何保证消息数据处理的  一致性问题。

 三、常见的MQ产品

RabbitMQ使用步骤

第一步确保rabbitmq启动并且可以访问15672

第二步导入依赖

        <!-- rabbitmq --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>

第三步配置

rabbitmq:host: ipport: 5672username: guestpassword: guestvirtual-host: /listener:simple:prefetch: 1 # 默认每次取出一条消息消费, 消费完成取下一条acknowledge-mode: manual # 设置消费端手动ack确认  不写默认为自动确认(auto)retry:enabled: true # 是否支持重试publisher-confirm-type: correlated  #确认消息已发送到交换机(Exchange)publisher-returns: true  #确认消息已发送到队列(Queue)     

auto自动确认

  1. 消息成功被消费,没有抛出异常,则自动确认,回复ack。
  2. 当抛出ImmediateAcknowledgeAmqpException异常,则视为成功消费,确认该消息。
  3. 当抛出AmqpRejectAndDontRequeueException异常的时候,则消息会被拒绝丢弃,并且不会重新入队。
  4. 其他的异常,则消息会被拒绝,且requeue = true(默认就是true)时会重新入队

manual手工确认(推荐使用!可以防止消息丢失)

无论有没有异常,标准只有是否主动调用basicAck()、basicNack()等方法,没有调用则一直阻塞.

因此有异常时,(有重试就重试),抛出异常后,没有调用时,还是会一直阻塞。即使是auto模式的那两个特殊的异常,在manual中都是一样的,不会有特殊处理.

官网对应模式介绍:RabbitMQ Tutorials | RabbitMQ

第四步编写生产者和消费者

        这里写一个登录成功发送消息给登录人的业务(普通队列模式) 

  • P:生产者,也就是要发送消息的程序
  • C:消费者:消息的接受者,会一直等待消息到 

生产者

        

  1. String exchange(交换机名)

    • 交换器的名称。交换器是一种逻辑实体,用于分发消息到相应的队列。你可以创建自定义的交换器类型,如 Direct、Fanout、Topic 或者 Headers 等。
  2. String routingKey(队列名)

    • 路由键。它是消息与队列之间的桥梁,决定了消息将被发送到哪个队列。路由键的值应匹配队列绑定到交换器时所使用的键。
  3. Object message(消息对象)

    • 要发送的消息对象。这个对象将被转换成字节流,然后发送到 RabbitMQ。Spring AMQP 使用 MessageConverter 将 Java 对象转换为 AMQP 格式的字节流。默认情况下,SimpleMessageConverter 可以处理简单的字符串、Java 序列化对象等。你可以通过配置 RabbitTemplate 的 messageConverter 属性来自定义消息转换器。
  4. MessagePostProcessor messagePostProcessor

    • 这是一个接口,用于在消息发送前对其进行进一步的修改。你可以在这个处理器中设置消息头、属性或其他特定信息。MessagePostProcessor 接口有一个方法 postProcessMessage(Message message),你可以在这里修改消息实例。
  5. CorrelationData correlationData

    • 相关数据,主要用于跟踪消息的发送结果。在异步发送消息的情况下,你可以使用此参数来关联发送请求和响应。CorrelationData 包含一个唯一标识符,用于识别消息。当收到响应时,可以通过这个标识符找到原始请求。

      

        发邮件是发给一个人,所以这里只需要传一个队列名和登录人对象。(发送给多个队列时需            要用到交换机)

        

消费者:

//@Header从消息头中提取消息的递送标签,标签是唯一的,对应唯一的消息
@RabbitListener(queuesToDeclare = @Queue("login_queue"))
public void test01(User getUser, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long         deliveryTag)
{try {发送邮件的代码……//手动确认消息channel.basicAck(deliveryTag,true);} catch (MessagingException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);}}

 如果配置了手工消费,一定要消费完后手动确认消息,不然就会重复接收该消息,导致后面的消息接受不到!

         

http://www.dinnco.com/news/58917.html

相关文章:

  • 营销型网站特征google本地搜索
  • 做气球装饰可以上哪些网站做网站需要多少钱
  • 企业选什么wordpress主题深圳搜索seo优化排名
  • 百度seo网站优化网站排名优化怎样做
  • 网站建设相关知识哈尔滨seo关键词
  • 网站建设策划方案如何写最牛餐饮营销手段
  • 外贸免费建设网站制作百度推广售后客服电话
  • 网站备案怎么备案淘宝排名查询
  • 网站 建设 毕业设计 要求青岛seo优化公司
  • 网站建设 网络推广seo服务包括哪些
  • 看看铜陵新闻个人网站seo入门
  • 做网站 贴吧百度百家号注册
  • 网站模板html整站青岛seo软件
  • 做模型的网站有哪些友链大全
  • 北京商城网站开发北京seo优化多少钱
  • 有做h的小说网站谷歌商店paypal三件套
  • 用dw做网站图片的基本尺寸网站免费推广网站
  • 北京各大网站推广平台哪家好站长全网指数查询
  • wordpress 刷新 link企业网站关键词优化
  • wordpress后台添加底部菜单青岛seo精灵
  • 专业建站提供商首页关键词排名代发
  • 南充做网站电话web3域名注册
  • 做网站负责人风险google google
  • 武汉ui设计公司温州seo公司
  • 做网站时管理员权限的页面北京广告公司
  • 网站建设京icp备新网
  • 注册资金必须实缴吗广东seo推广外包
  • 商会网站制作互联网推广软件
  • 南宁营销型网站专家seo推广思路
  • 网站建设报价表下载百度灰色关键词代发