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

做动态网站的软件有哪些内容快手流量推广免费网站

做动态网站的软件有哪些内容,快手流量推广免费网站,北京协会网站建设,网站cdn 自己做一、系统监控:RabbitMQ的各项性能指标及监控 Message Rates:消息率包含了publish,deliver/get,ack等方面的数据,反映了消息在系统中流转的情况。Queue Length:队列长度反映了系统当前的负载情况。如果队列…

一、系统监控:RabbitMQ的各项性能指标及监控

  1. Message Rates:消息率包含了publish,deliver/get,ack等方面的数据,反映了消息在系统中流转的情况。
  2. Queue Length:队列长度反映了系统当前的负载情况。如果队列中的消息过多,可能需要增加消费者来处理消息,或者检查消费者是否出现问题。
  3. Memory Usage:内存使用量可以反应RabbitMQ节点的消耗情况,如果内存使用高,则需要检查是否有资源泄露或因处理大量消息产生的压力。
  4. Disk Usage:磁盘使用情况,反映消息持久化的存储压力。

你可以使用RabbitMQ Manager来查看以上数据,在管理界面中它提供了实时的图形化数据展示。此外,RabbitMQ也提供了HTTP API,可以通过编程的方式获取这些数据。

二、问题定位:常见的RabbitMQ问题及解决办法

  1. 队列积压:积压的问题一般是因为消费者处理消息的速度跟不上生产者的产生速度。可以通过增加消费者,或者优化消费者的处理逻辑,提升其消费速度。
  2. 资源过载:如果RabbitMQ的CPU或内存消耗过高,可能是因为处理的消息量过大,或者存在程序的资源泄露。需要结合具体的监控数据,进行具体的优化。
  3. 网络问题:RabbitMQ依赖于网络连接,如果出现网络问题,可能会引发一系列的问题。可以通过查看RabbitMQ的日志,定位具体的问题。

三、性能优化:提升RabbitMQ性能的建议和技巧

  1. 合理设置队列长度和消息过期时间:长队列和过多的过期消息会影响RabbitMQ的性能。可以设置队列的长度限制,合理设定TTL,过期的消息会自动被删除,从而节省内存。
  2. 使用持久化:如果需要保证消息的可靠性,应将消息、队列和交换器设置为持久化的。但请注意,持久化会有一定的性能开销。
  3. 合理设置Prefetch Count:Prefetch Count决定了消费者从队列中预取的消息数量,适当的预取可以降低消费者的确认延迟,从而提高消费的吞吐量。但设置过大也会消耗更多的内存。
  4. 使用批确认提高性能:每次消息的确认都会带来一次网络往返的开销,一种提升性能的方式就是使用批量确认。消费者可以等待多条消息后再发送一次确认,从而提高效率。

四、常见问题及解决样例:在 RabbitMQ 中,Channel与队列的映射和消息确认消费的方式非常重要。下面展示如何在Spring Boot中设置。

@Autowired
private ConnectionFactory connectionFactory;@Bean
public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory() {SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setConcurrentConsumers(3);factory.setMaxConcurrentConsumers(5);factory.setAcknowledgeMode(AcknowledgeMode.AUTO); return factory;
}

在上面的代码中,setConcurrentConsumers(3)设置了并发消费者的初始值为3,setMaxConcurrentConsumers(5)设置了最大的并发消费者数为5,setAcknowledgeMode(AcknowledgeMode.AUTO)设置了消息确认消费的方式为自动确认。

五、监控样例: 您可以使用 Actuator 提供的 /actuator/health EndPoint 来检查RabbitMQ的健康状态。

在SpringBoot的pom.xml添加如下配置:

xml

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

启动SpringBoot应用后,我们可以通过访问http://localhost:8080/actuator/health 来查看 RabbitMQ的健康状态。

六、性能优化样例:在 Spring Boot 中,我们也可以设置预取和确认模式来提高 RabbitMQ 的性能。预获取是指 RabbitMQ 会一次性推送多条消息给消费者,手动确认模式替代了自动确认模方式,可以防止消息丢失。

java

@Bean
public SimpleRabbitListenerContainerFactory rabbitListenerContainerFactory() {SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setPrefetchCount(10);  // 设置预取数量为10factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);  // 手动确认模式return factory;
}

在上面的代码中,factory.setPrefetchCount(10)设置了预取数量为10,factory.setAcknowledgeMode(AcknowledgeMode.MANUAL)设置了手动确认模式。在使用手动确认模式时,需要在消费者的方法中添加 Channel 参数,并调用 channel.basicAck 方法来确认消息:

java

@RabbitListener(queues = "myqueue")
public void handleMessage(Message message, Channel channel) throws Exception {try {// Do some workchannel.basicAck(deliveryTag, false);  } catch (Exception e) {channel.basicNack(deliveryTag, false, true); }
}

在上面的代码中,如果处理消息的逻辑抛出异常,我们需要调用 channel.basicNack 方法来拒绝消息,并设置 requeue 为 true,这样 RabbitMQ 会再次将这条消息推送给消费者。

http://www.ritt.cn/news/20846.html

相关文章:

  • 网站内容设计是什么广告平台网
  • 网站建设 网站推广整站seo排名费用价格
  • 专业网站设计公司有哪些广州seo优化
  • 上市公司中 哪家网站做的好seo兼职平台
  • 设计网站做的工作步骤是在线刷seo
  • 写真盗版网站怎么做最新新闻实时新闻
  • 新乡做网站公司电话武汉新一轮疫情
  • 杭州化工网站建设seo排名优化排行
  • 国外做名片网站广州seo排名优化
  • 做网站攻略广东seo点击排名软件哪里好
  • 多语言网站建设价格百度公司官方网站
  • 利用技术搭建网站做博彩代理网站模板怎么建站
  • 保险做的好的网站百度认证平台
  • 网站开发与设计静态网页源代码网络营销技巧培训
  • 做博彩网站要找谁宁波关键词优化排名工具
  • php网站怎么建设什么是网站推广
  • 做个网站好还是做淘宝好google推广妙招
  • 女性网站模板百度联盟官网
  • 网站做一些流量互换网络推广怎么收费
  • 网站开发人员是干嘛的推广文案
  • 品质网站建设百度旧版本下载
  • 网站设计尺寸宽带推广方案
  • 百度seo价格查询系统郑州seo优化哪家好
  • 网络工作室有什么项目武汉seo招聘网
  • 网站建设网络推广的好处广告联盟论坛
  • 网站做淘宝客还行吗怎么制作微信小程序
  • 小米商城网页设计论文长沙seo优化价格
  • 做网站按什么收费多少seo管家
  • 道客网站建设推广小程序危机舆情公关公司
  • 网站建设系统公司百度认证