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

专门做肥料外贸的网站做好网络推广

专门做肥料外贸的网站,做好网络推广,微信官方网站怎么进入,汕头市建设网站6.1场景: 1.定时发布文章 2.秒杀之后,给30分钟时间进行支付,如果30分钟后,没有支付,订单取消。 3.预约餐厅,提前半个小时发短信通知用户。 A -> 13:00 17:00 16:30 延迟时间: 7*30 * 60 *…

6.1场景:
1.定时发布文章

2.秒杀之后,给30分钟时间进行支付,如果30分钟后,没有支付,订单取消。

3.预约餐厅,提前半个小时发短信通知用户。

A -> 13:00 17:00 16:30 延迟时间: 7*30 * 60 * 1000

B -> 11:00 18:00 17:30 延迟时间: 13*30 * 60 * 1000

C -> 8:00 14:00 13:30 延迟时间: 11*30 * 60 * 1000

6.2第一种方式:创建具有超时功能且绑定死信交换机的消息队列
@Bean
public Queue directQueueLong(){
return QueueBuilder.durable(“业务队列名称”)
.deadLetterExchange(“死信交换机名称”)
.deadLetterRoutingKey(“死信队列 RoutingKey”)
.ttl(20000) // 消息停留时间
//.maxLength(500)
.build();
}

监听死信队列,即可处理超时的消息队列

缺点:

上述实现方式中,ttl延时队列中所有的消息超时时间都是一样的,如果不同消息想设置不一样的超时时间,就需要建立多个不同超时时间的消息队列,比较麻烦,且不利于维护。
6.3第二种方式:创建通用延时消息
rabbitTemplate.convertAndSend(“交换机名称”, “RoutingKey”,“对象”,
message => {

		        message.getMessageProperties().setExpiration(String.valueOf(5000))return message;});

缺点:

该种方式可以创建一个承载不同超时时间消息的消息队列,但是这种方式有一个问题,如果消息队列中排在前面的消息没有到超时时间,即使后面的消息到了超时时间,先到超时时间的消息也不会进入死信队列,而是先检查排在最前面的消息队列是否到了超时时间,如果到了超时时间才会继续检查后面的消息。
6.4 第三种方式:使用rabbitmq的延时队列插件,实现同一个队列中有多个不同超时时间的消息,并按时间超时顺序出队
6.4.1下载延迟插件
在 RabbitMQ 的 3.5.7 版本之后,提供了一个插件(rabbitmq-delayed-message-exchange)来实现延迟队列 ,同时需保证 Erlang/OPT 版本为 18.0 之后。

我这里 MQ 的版本是 3.10.0 现在去 GitHub 上根据版本号下载插件

6.4.2安装插件并启用
我用的是 Docker 客户端,下载完成后直接把插件放在 /root 目录,然后拷贝到容器内plugins目录下(rabbitmq是容器的name,也可以使用容器id)

docker cp /home/208/rabbitmq_delayed_message_exchange-3.10.0.ez rabbitmq:/plugins
进入 Docker 容器

docker exec -it rabbitmq /bin/bash
在plugins内启用插件

#先执行,解除防火墙限制,增加文件权限
umask 0022
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
退出容器

exit
重启 RabbitMQ

docker restart rabbitmq
通过UI查看

6.4.3原理

6.4.4如何使用?
1、消费者

2、生产者

6.延迟队列
6.1场景:
1.定时发布文章

2.秒杀之后,给30分钟时间进行支付,如果30分钟后,没有支付,订单取消。

3.预约餐厅,提前半个小时发短信通知用户。

A -> 13:00 17:00 16:30 延迟时间: 7*30 * 60 * 1000

B -> 11:00 18:00 17:30 延迟时间: 13*30 * 60 * 1000

C -> 8:00 14:00 13:30 延迟时间: 11*30 * 60 * 1000

6.2第一种方式:创建具有超时功能且绑定死信交换机的消息队列
@Bean
public Queue directQueueLong(){
return QueueBuilder.durable(“业务队列名称”)
.deadLetterExchange(“死信交换机名称”)
.deadLetterRoutingKey(“死信队列 RoutingKey”)
.ttl(20000) // 消息停留时间
//.maxLength(500)
.build();
}

监听死信队列,即可处理超时的消息队列

缺点:

上述实现方式中,ttl延时队列中所有的消息超时时间都是一样的,如果不同消息想设置不一样的超时时间,就需要建立多个不同超时时间的消息队列,比较麻烦,且不利于维护。
6.3第二种方式:创建通用延时消息
rabbitTemplate.convertAndSend(“交换机名称”, “RoutingKey”,“对象”,
message => {

		        message.getMessageProperties().setExpiration(String.valueOf(5000))return message;});

缺点:

该种方式可以创建一个承载不同超时时间消息的消息队列,但是这种方式有一个问题,如果消息队列中排在前面的消息没有到超时时间,即使后面的消息到了超时时间,先到超时时间的消息也不会进入死信队列,而是先检查排在最前面的消息队列是否到了超时时间,如果到了超时时间才会继续检查后面的消息。
6.4 第三种方式:使用rabbitmq的延时队列插件,实现同一个队列中有多个不同超时时间的消息,并按时间超时顺序出队
6.4.1下载延迟插件
在 RabbitMQ 的 3.5.7 版本之后,提供了一个插件(rabbitmq-delayed-message-exchange)来实现延迟队列 ,同时需保证 Erlang/OPT 版本为 18.0 之后。
添加链接描述
我这里 MQ 的版本是 3.10.0 现在去 GitHub 上根据版本号下载插件

6.4.2安装插件并启用
我用的是 Docker 客户端,下载完成后直接把插件放在 /root 目录,然后拷贝到容器内plugins目录下(rabbitmq是容器的name,也可以使用容器id)

docker cp /home/208/rabbitmq_delayed_message_exchange-3.10.0.ez rabbitmq:/plugins
进入 Docker 容器

docker exec -it rabbitmq /bin/bash
在plugins内启用插件

#先执行,解除防火墙限制,增加文件权限
umask 0022
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
退出容器

exit
重启 RabbitMQ

docker restart rabbitmq
通过UI查看
在这里插入图片描述

6.4.3原理

在这里插入图片描述

6.4.4如何使用?
1、消费者
在这里插入图片描述

2、生产者
在这里插入图片描述
在这里插入图片描述

http://www.15wanjia.com/news/23112.html

相关文章:

  • 关于网站项目建设的申请有哪些可以免费推广的平台
  • 企业免费网站建设模板下载360推广开户
  • 有什么网站可以免费seo顾问服务四川
  • 怎么用ps做网站首页营销网络的建设有哪些
  • 网站建设如何设计数据库百度站长工具怎么查排名
  • 没有数据库的网站怎么接推广
  • 湖北网站优化公司合作seo公司
  • ppt网站超链接怎么做网上推广渠道有哪些
  • 网站运维推广怎么做网站快速收录付费入口
  • 淘宝客app定制广东seo教程
  • 郑州网站建设喝彩东莞seo计费管理
  • 专业团队电影seo数据
  • 公司找私人做网站seo人员培训
  • 湖南网站建设设计百度指数1000搜索量有多少
  • php企业网站域名ip查询
  • 电子商务网站建设与管理—李建忠网页优化包括什么
  • 温州网络公司网站建设百色seo关键词优化公司
  • 教学互动网站开发背景seo引擎搜索
  • 做餐饮培训网站广告百度官网地址
  • 黄山做网站怎样做搜索引擎推广
  • 部门网站建设整改2021搜索引擎排名
  • 做设计必须知道的几个网站吗产品推广文案100字
  • 微网站的建设人力资源培训机构
  • 做司法考试真题的网站网站查询进入
  • 湛江建设工程造价信息网中国seo公司
  • 域名注册好怎么建设网站武汉网站竞价推广
  • 承接网站建设 优帮云百度知识营销
  • 移动端网站建站视频教程长沙网动网络科技有限公司
  • 自己的电脑做网站当服务器使用内蒙古seo
  • 珠海网站建设网络公司怎么样东莞做网站公司首选