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

怎么做找优惠券的网站中国品牌网官网入口

怎么做找优惠券的网站,中国品牌网官网入口,百度竞价平台官网,做网站时版权怎么写物联网中RocketMQ的使用 1. 背景 随着物联网行业的发展、智能设备数量越来越多,很多常见的智能设备都进入了千家万户;随着设备数量的增加,也对后台系统的性能提出新的挑战。 在日常中,存在一些特定的场景,属于高并发请…

物联网中RocketMQ的使用

1. 背景

       随着物联网行业的发展、智能设备数量越来越多,很多常见的智能设备都进入了千家万户;随着设备数量的增加,也对后台系统的性能提出新的挑战。

       在日常中,存在一些特定的场景,属于高并发请求,瞬时的压力会达到20w/s。为了保证用户的使用体验,提高服务器的处理能力刻不容缓。那应该如何来提高后台服务处理能力呢?

系统访问的两种常见方式:

  • 同步方式,该方式是常用的一种方式,当请求时,就会阻塞当前线程等待返回结果。该方式开发很简单,但是在高并发的情况下,会导致系统负载剧增,处理能力下降,甚至会导致上游服务等待过长产生熔断。
  • 异步方式,当我们请求时,不需要阻塞当前线程(主线程),当时结果处理完之后,再回调告诉主线程;该方式很适合与高并发的场景,但开发比较困难,会导致失败的情况。

2. 缓冲池

       在讲解RocketMQ之前,首先来介绍缓冲池的概念:

       缓冲池是计算机里的概念,很像生活中的蓄水池:从上游来的水并不是直接到达用户家里,而是先存储到一个水池里面;其优点有:

  • 多余的水可以在水池里面存起来,防止压力直接就传到下游;
  • 控制水池的阀门可以调节出水大小,可以根据实际的使用控制水流。

3. RocketMq的组成

       有了缓存池的概念,就很好理解RocketMQ工作的基本原理,在RocketMQ中主要有三部分组成:

  • 生产者(producer),生产者用户生产消息,就像上游的水。
  • brokerbroker就像蓄水池一样,会将生产的消息存储起来。
  • 消费者(consumer),将broker队列里面的消息拉出来消费。

其工作的原理图如下:

在这里插入图片描述

       通过生产者将消息传递到broker存储起来,然后消费者去消费broker里面的消息,其中broker是路由,具体的存储是采用了队列数据结构。

4. RocketMQ在物联网中的应用

       根据它的组成和原理,其非常合适用于异步解耦。比如在某个时间段,大量的请求来到云服务,如果云服务采用同步的方式去控制设备,势必导致服务延迟严重,出现大批量的失败。

       因此为了达到异步解耦,流量削峰,当大量的请求来到云服务的时候,并不是直接去控制设备,而是先将控制消息存入RocketMQ中,然后通过消费者去控制设备。因此具体的控制流程图如下:

在这里插入图片描述

       如图所示,当控制参数来到服务时,现将控制的参数封装为message,然后通过生产者将消息存放到RocketMQbroker存储起来,在消费者端将启动多线程去消费消费消息—即去控制设备,当设备控制完成后,将控制的结果告诉上游服务。

       通过以上的设计,不管多大的流量来,都先将参数存入rocketMQ中,然后慢慢去消费,有效地保护了云端服务,提供了云端的性能,提高了用户的使用体验。

5. 使用RocketMQ搭建一个简单的生产者和消费者demo

  • 前提—RocketMQ已经搭建好

  • 依赖

<dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.2.2</version>
</dependency>
  • 配置文件
server.port: 8085rocketmq:name-server: 10.16.17.246:9876producer:group: rocket-demo
  • 首先是生产者,这里开发了一个接口:
@RestController()
@RequestMapping("/producer")
public class ProducerController {// 注入@ResourceRocketMQTemplate rocketMQTemplate;@PostMapping("/push")public void producer(){ProducerDto producerDto = new ProducerDto();Random random = new Random();producerDto.setApplianceId(String.valueOf(random.nextInt()));producerDto.setReqId(UUID.randomUUID().toString());// 将producerDto 封装为消息Message<ProducerDto> message = withPayload(producerDto).setHeader(PROPERTY_KEYS, producerDto.getReqId()).build();System.out.println("生产的消息为:" + message);// 将消息塞入指定的TOPICrocketMQTemplate.syncSend(TOPIC_DEMO, message);}
}

其中,ProducerDto消息体有applianceIdreqId两个参数,broker中将消息路由到与topic绑定的队列中。

  • 消费者
@RocketMQMessageListener(consumeThreadNumber = 16,topic = TOPIC_DEMO,consumerGroup = "consumer_demo_group")
@Component
public class Consumer implements RocketMQListener<MessageExt> {private final String CHARSET = Charset.defaultCharset().name();@Overridepublic void onMessage(MessageExt message) {byte[] body = message.getBody();String str = new String(body, Charset.forName(this.CHARSET));System.out.println("消费者消费的消息为: " + str);}
}

在消费者类上加上@RocketMQMessageListener、@Component注解即可实现消费。

  • 结果, 实现了消息的生产和消费
生产的消息为:GenericMessage [payload=ProducerDto(reqId=086a5666-922a-4345-b408-956ba6bc18d9, applianceId=2140322229), headers={KEYS=086a5666-922a-4345-b408-956ba6bc18d9, id=12816bba-1
259-469a-d0ff-e42311a27fe7, timestamp=1676713480448}]
消费者消费的消息为: {"reqId":"086a5666-922a-4345-b408-956ba6bc18d9","applianceId":"2140322229"} 

6. 结语

以上是关于RocketMQ的简单介绍,只是皮毛而已,里面还有很多的功能可以挖掘。

http://www.yayakq.cn/news/649792/

相关文章:

  • 公司网站建设计入什么费用西安高端网站设计公司
  • aspcms网站地图模板企业文化模板
  • 大型网站的例子昆明网站如何制作
  • 网站建设第一品牌 网站设计京东企业官网
  • 做网站公司哪家公司网站前端设计与制作ppt
  • 玉田网站设计公司上海搬家公司哪家口碑最好
  • 网站留言板作用wordpress 近期文章代码
  • 服务器做视频网站吗win2008怎么做网站
  • vs怎么建手机网站新乡网站开发的公司电话
  • 个人网站效果图咋做做网站的域名和空间是什么意思
  • 网站建立的重要性辽宁建设资质申报网站
  • 杭州搭建网站网站速成
  • 红孩子母婴网站开发背景广东衍发建设管理有限公司公司网站
  • 网站关键词添加多少个做网站要多少回扣
  • 关于网站建设需要的研究方法珠海市建设工程信息网
  • 做视频网站玩什么配置正规推广平台
  • 张家港网站制作公司搜索关键词
  • 购物网站排名2017广州网站建设哪家公司好
  • quot 网站建设话术 quotwordpress主题克隆
  • 网站建设报价乱不一城乡建设局网站
  • 可以免费学编程的网站wordpress博客收录查询
  • 做网站是用什么语言网站类的知识
  • 江苏省交通运输厅门户网站建设管理办法澄海建网站
  • 选择一个域名进行网站建设临海市住房和城乡建设规划局 网站
  • 福安建设网站重视网站阵地建设
  • 江西专业的网站建设制作鹰潭市建设局网站
  • 广西住房和城乡建设厅网站主页建设手机网站公司
  • 北京企业网站建设推荐wordpress做动态页面
  • 手机app 网站宿迁房价2023年最新房价
  • 国际站wap端流量广州深圳做网站