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

调查问卷在哪个网站做重庆网站建设

调查问卷在哪个网站做,重庆网站建设,网站需要什么费用,网络营销服务商有哪些这次主要选用RabbitMQ消息队列来对判题服务和题目服务解耦,题目服务只需要向消息队列发送消息,判题服务从消息队列中取信息去执行判题,然后异步更新数据库即可。 五一宝宝请快点跑~~~~~ 先回顾一下RabbitMQ (1)引入依…

这次主要选用RabbitMQ消息队列来对判题服务和题目服务解耦,题目服务只需要向消息队列发送消息,判题服务从消息队列中取信息去执行判题,然后异步更新数据库即可。

五一宝宝请快点跑~~~~~

先回顾一下RabbitMQ

(1)引入依赖

<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-amqp -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId><version>2.7.2</version>
</dependency>

(2)在yml中引入配置

spring:rabbitmq:host: localhostport: 5672password: guestusername: guest

(3)创建交换机和队列

/*** 用于创建测试程序用到的交换机和队列(只用在程序启动前执行一次)*/
public class MqInitMain {public static void main(String[] args) {try {ConnectionFactory factory = new ConnectionFactory();factory.setHost("localhost");Connection connection = factory.newConnection();Channel channel = connection.createChannel();String EXCHANGE_NAME = "code_exchange";channel.exchangeDeclare(EXCHANGE_NAME, "direct");// 创建队列,随机分配一个队列名称String queueName = "code_queue";channel.queueDeclare(queueName, true, false, false, null);channel.queueBind(queueName, EXCHANGE_NAME, "my_routingKey");} catch (Exception e) {}}
}

(4)生产者代码

@Component
public class MyMessageProducer {@Resourceprivate RabbitTemplate rabbitTemplate;public void sendMessage(String exchange, String routingKey, String message) {rabbitTemplate.convertAndSend(exchange, routingKey, message);}}

(5)消费者代码

@Component
@Slf4j
public class MyMessageConsumer {// 指定程序监听的消息队列和确认机制@SneakyThrows@RabbitListener(queues = {"code_queue"}, ackMode = "MANUAL")public void receiveMessage(String message, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag) {log.info("receiveMessage message = {}", message);channel.basicAck(deliveryTag, false);}}

(6)单元测试执行

@SpringBootTest
class MyMessageProducerTest {@Resourceprivate MyMessageProducer myMessageProducer;@Testvoid sendMessage() {myMessageProducer.sendMessage("code_exchange", "my_routingKey", "你好呀");}
}

项目实践

要传递的消息是什么?题目提交 id

题目服务中,把原本的本地异步执行改为向消息队列发送消息:

// 发送消息
myMessageProducer.sendMessage("code_exchange", "my_routingKey", String.valueOf(questionSubmitId));
// 执行判题服务
//        CompletableFuture.runAsync(() -> {
//            judgeFeignClient.doJudge(questionSubmitId);
//        });

判题服务中,监听消息,执行判题:

@Component
@Slf4j
public class MyMessageConsumer {@Resourceprivate JudgeService judgeService;// 指定程序监听的消息队列和确认机制@SneakyThrows@RabbitListener(queues = {"code_queue"}, ackMode = "MANUAL")public void receiveMessage(String message, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag) {log.info("receiveMessage message = {}", message);long questionSubmitId = Long.parseLong(message);try {judgeService.doJudge(questionSubmitId);channel.basicAck(deliveryTag, false);} catch (Exception e) {channel.basicNack(deliveryTag, false, false);}}}

消息确认机制:basicAck  basicNack

在 RabbitMQ 中,消息从生产者发送到队列,然后被消费者消费。为了确保消息被正确处理,RabbitMQ 提供了一种机制,让消费者可以确认消息是否已经被成功处理。这就是 消息确认机制

basicAck:

作用:消费者告诉 RabbitMQ,我已经成功处理了这条消息。

参数:

(1)deliveryTag:消息的唯一标识符,RabbitMQ 用它来跟踪每条消息。

(2)multiple:布尔值,表示是否确认多个消息。如果为 true,则确认所有小于等于deliveryTag 的消息;如果为 false,则只确认当前的 deliveryTag 消息。

 示例:

channel.basicAck(deliveryTag, false);

 这行代码的意思是:“我成功处理了 deliveryTag 指定的消息,请从队列中移除它。”

basicNack:

作用:消费者告诉 RabbitMQ,我无法处理这条消息。

参数

(1)deliveryTag:消息的唯一标识符。

(2)multiple:布尔值,表示是否拒绝多个消息。如果为 true,则拒绝所有小于等于 deliveryTag 的消息;如果为 false,则只拒绝当前的 deliveryTag 消息。

(3)requeue:布尔值,表示是否将消息重新放回队列。如果为 true,则将消息重新放回队列,等待其他消费者处理;如果为 false,则丢弃这条消息。

示例:

channel.basicNack(deliveryTag, false, false);

这行代码的意思是:“我无法处理 deliveryTag 指定的消息,请丢弃它。”

总结

basicAck:确认消息已成功处理,从队列中移除。

basicNack:确认消息处理失败,可以选择重新放回队列或丢弃。

http://www.dtcms.com/wzjs/133224.html

相关文章:

  • 网站死链存在的问题在线培训app
  • bt网页游戏网站软文广告素材
  • 不用服务器做网站网络推广一个月的收入
  • 网站建设3d插件乐陵seo外包
  • 电商运营推广方案上海网络营销seo
  • 龙岩网站建设要多久吉林网站推广公司
  • 住房和城乡建设部官方网站发布企业网站seo案例
  • 域名解析映射到网站空间怎么做成都十大营销策划公司
  • 做飞机票的图片的网站网址之家
  • 好的国外设计网站推荐seo实战密码第三版pdf下载
  • 网站开发广告语大全东莞优化疫情防控措施
  • 运营推广网站建设中国十大小说网站排名
  • 做一个网站APP价格做免费推广的平台
  • 南京浦口做网站点嘉兴新站seo外包
  • 门户型网站建设十大搜索引擎排行榜
  • 上海 网站 备案seo技术软件
  • 新乡做网站费用今日小说搜索百度风云榜
  • 物流网站建设公司哪家好2023第二波疫情已经到来
  • 网站的在线聊天怎么做推广app佣金平台正规
  • 34线城市做网站推广广告投放怎么做
  • 天津市做企业标准网站做一个公司网站需要多少钱
  • 自己的网站怎么做app广西壮族自治区免费百度推广
  • 茶文化网站制作怎么买域名自己做网站
  • wordpress 插件 慢seo优化行业
  • 第五冶金建设公司职工大学网站百度旗下的所有产品
  • 青岛的网站设计公司靠网络营销火起来的企业
  • 真人做爰视频网站免费下载seo学堂
  • 送网站建设谷歌海外广告投放
  • 陕西整站关键词自然排名优化关闭站长工具seo综合查询
  • 门户网站的建设与维护详情页设计