- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Java EE 和 JMS 的新手,正在考虑使用 JMS 进行实现。
考虑以下场景:
场景
用户点击一个 servlet。然后从该 servlet 将消息放入 JMS 服务器/队列。然后将响应发送回用户,说“消息已排队”。
选项 1
消费者/MDB 从 JMS 队列接收消息并处理它。这是正常操作,非常标准。
选项 2
没有消费者(无论出于何种原因)或接收者处理消息的速度太慢。所以我想要的是队列中的消息超时。一旦超时,应发送电子邮件等(电子邮件仅作为示例)。
阅读我在 QueuSender 类中找到的 API 规范/Java EE 6 教程
void send(Message message, int deliveryMode, int priority, long timeToLive)
因此,通过设置 timeToLive,消息将从队列中逐出。问题是没有“接口(interface)/回调”来知道消息已被驱逐。它就这样消失了。还是我弄错了?
我想到的另一种方法是让线程监视队列并逐出“过期”的消息并将它们从队列中拉出。但我不认为这是可能的,是吗?
任何关于此事的线索都将不胜感激。
最佳答案
您必须使用一些特定于实现的功能来满足您的要求。 JMS 规范既没有定义对超时消息执行的操作,也没有在轮询队列中的消息时为您提供任何合理的标准选择。
大多数(如果不是全部)JMS 实现都提供 DLQ(死信队列)的概念。如果消息无法传递给常规消费者或超时,JMS 实现很可能能够将消息移动到 DLQ,DLQ 基本上也是一个具有自己的监听器的常规队列。
因此,如果您设置两个队列,Q1 和 Q2,并将 Q2 配置为 Q1 的 DLQ,您将在 Q1 的监听器中执行正常的请求处理,并为 Q2 实现一个额外的监听器来执行错误/超时处理.
关于java - JMS 超时或 TimeToLive,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7526367/
我正在尝试在 Blueprint XML Camel 路由中设置消息过期时间。我想要设置为过期的值保存在消息正文中 (a protobuf )。 这是我的代码:-
我是 Java EE 和 JMS 的新手,正在考虑使用 JMS 进行实现。 考虑以下场景: 场景 用户点击一个 servlet。然后从该 servlet 将消息放入 JMS 服务器/队列。然后将响应发
最近(在一次采访中)我被要求设计 HashMap与每个 key 关联的 TTL。我使用下面给出的类似方法完成了它,但在他看来,这不是一个好方法,因为这需要在整个 map 上进行迭代,如果 map 大小
我想在 RedisHash 中动态设置 timeToLive 值。即来自属性文件。 我知道@RedisHash是一个接口(interface),所有字段都是最终的,我们无法动态赋值。 @TimeToL
我想在 RedisHash 中动态设置 timeToLive 值。即来自属性文件。 我知道@RedisHash是一个接口(interface),所有字段都是最终的,我们无法动态赋值。 @TimeToL
我想了解 timeToLive 属性是如何工作的? 这是当你从池中获取连接时,特意关闭连接并返回到池中的时间间隔? API 我希望使用持久连接的客户端每隔几秒关闭一次,这样对负载均衡器的请求每隔几秒就
如果我在生产者中设置了 TimeToLive,我的订阅者不会收到任何消息。我使用 activeMQ V.5.13.3 作为消息代理。 我的制作人 javax.naming.Context ctx =
我正在尝试在 JmsTemplate 上设置 TTL,但消息永远不会过期。当我使用 ActiveMQ Web 控制台在消息上设置 TTL 时,它会在设置的时间段后过期。 这就是我现在拥有的:
我无法仅通过 Google 找出这个问题。我正在连接到一个非持久 EMS 主题,该主题发布一组数据的更新。如果我跳过一些更新,也没关系,因为接下来的更新无论如何都会覆盖它。 在 EMS 主题上发布的消
我有一个 Spring 3.0.x Web 项目,它向用户显示一个链接页面,但我遇到了一些困惑。目前,我正在使用 EhCache 2.1.0 来缓存我的内容,这些内容都是几乎千载难逢的静态内容。内容本
我有一个 Azure Function,其输出绑定(bind)到 Azure Cosmos DB 以保存项目。我正在尝试在项目级别设置 TimeToLive (我知道 TTL 必须打开才能使容器正常工
我有一个用例,其中单个条目需要在特定时间从缓存中删除。 TTL 需要设置在键上而不是缓存级别 关注此spring redis documentation我试图实现特定于关键的 TTL,但它不起作用。没
我是一名优秀的程序员,十分优秀!