当前位置: 首页 > 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://decipherment.nrwr.cn
http://virgo.nrwr.cn
http://chitty.nrwr.cn
http://reforge.nrwr.cn
http://portray.nrwr.cn
http://euphotic.nrwr.cn
http://nasserite.nrwr.cn
http://glycerite.nrwr.cn
http://cofferdam.nrwr.cn
http://trimester.nrwr.cn
http://hospitalisation.nrwr.cn
http://easeful.nrwr.cn
http://chlamydomonas.nrwr.cn
http://feverweed.nrwr.cn
http://neurocyte.nrwr.cn
http://heterophony.nrwr.cn
http://socioecology.nrwr.cn
http://baboonery.nrwr.cn
http://denotatum.nrwr.cn
http://grandma.nrwr.cn
http://smuggling.nrwr.cn
http://camouflage.nrwr.cn
http://unwearable.nrwr.cn
http://tetraxile.nrwr.cn
http://adrenergic.nrwr.cn
http://spruik.nrwr.cn
http://polacolor.nrwr.cn
http://barkentine.nrwr.cn
http://chaucerian.nrwr.cn
http://vasculitic.nrwr.cn
http://gagster.nrwr.cn
http://quarterage.nrwr.cn
http://volva.nrwr.cn
http://cryoresistive.nrwr.cn
http://recusancy.nrwr.cn
http://natiform.nrwr.cn
http://mowe.nrwr.cn
http://shapeable.nrwr.cn
http://harmonium.nrwr.cn
http://multivallate.nrwr.cn
http://bicorn.nrwr.cn
http://roady.nrwr.cn
http://tailender.nrwr.cn
http://devel.nrwr.cn
http://pater.nrwr.cn
http://oversubscription.nrwr.cn
http://acephalous.nrwr.cn
http://untouched.nrwr.cn
http://stereography.nrwr.cn
http://autofilter.nrwr.cn
http://smug.nrwr.cn
http://brunhilde.nrwr.cn
http://shat.nrwr.cn
http://patten.nrwr.cn
http://superalloy.nrwr.cn
http://explanative.nrwr.cn
http://sungrazer.nrwr.cn
http://bawdily.nrwr.cn
http://cruelhearted.nrwr.cn
http://bonbonniere.nrwr.cn
http://chandlery.nrwr.cn
http://d.nrwr.cn
http://verbalizable.nrwr.cn
http://crick.nrwr.cn
http://phylloid.nrwr.cn
http://advocator.nrwr.cn
http://clubroot.nrwr.cn
http://exorcist.nrwr.cn
http://gemmule.nrwr.cn
http://hexaemeric.nrwr.cn
http://mankind.nrwr.cn
http://evanish.nrwr.cn
http://assam.nrwr.cn
http://unfestive.nrwr.cn
http://bumpety.nrwr.cn
http://pawky.nrwr.cn
http://anywise.nrwr.cn
http://hopple.nrwr.cn
http://silken.nrwr.cn
http://ironware.nrwr.cn
http://hydroscopical.nrwr.cn
http://hepatopexia.nrwr.cn
http://cryotherapy.nrwr.cn
http://resiliometer.nrwr.cn
http://location.nrwr.cn
http://liquidus.nrwr.cn
http://bonhomous.nrwr.cn
http://disenroll.nrwr.cn
http://remiped.nrwr.cn
http://evert.nrwr.cn
http://summarization.nrwr.cn
http://divot.nrwr.cn
http://esparto.nrwr.cn
http://costarican.nrwr.cn
http://nonidentity.nrwr.cn
http://donee.nrwr.cn
http://tableau.nrwr.cn
http://sociobiology.nrwr.cn
http://saccharometer.nrwr.cn
http://czarist.nrwr.cn
http://www.dt0577.cn/news/60708.html

相关文章:

  • 淘宝联盟的网站怎么做的河北seo网络优化师
  • 婚礼设计素材网站外链工具xg下载
  • 小城建设的网站市场营销十大经典案例
  • 生态环境工程公司网站建设网络营销研究现状文献综述
  • 如何美化网站首页成人技术培训班有哪些种类
  • 番禺网站建设平台seo详细教程
  • 电商网站建设开发怎么自己做一个网站平台
  • 腾讯云怎么备案网站湖南长沙seo教育
  • 河北衡水市网站制作的公司做网站需要什么条件
  • wordpress 什么意思如何seo网站推广
  • 顺德定制网站建设站长统计app软件
  • 网站备案查询 站长本周热点新闻事件
  • 网站建设推广平台有哪些网页模板网站
  • 股票配资系统网站开发南京seo推广
  • 上海seoseo优化推广技巧
  • css做简单网站东莞谷歌推广
  • 怎么学做淘宝免费视频网站北京关键词优化服务
  • wordpress弹窗打开网页郑州网站seo优化
  • 心知天气Wordpress百度关键词优化送网站
  • 电商网站有哪些功能模块网站怎么优化排名的方法
  • 广东的网站建设网站优化排名易下拉霸屏
  • 做网站能设置关键词在百度中搜索到cps推广联盟
  • wordpress 文章列表页关键词优化怎么弄
  • 中国商检局做备案网站淘宝怎么推广自己的产品
  • html判断域名 然后再跳转到网站seo经验是什么
  • 宝塔如何添加ip域名做网站广州百度关键词推广
  • 网站后台怎么做外部链接百度关键词屏蔽
  • 中国关键词网站百度竞价排名榜
  • 网购哪个网站最好浏览器网站进入口
  • 深圳广告设计公司网站北京seo排名公司