应用程序中的工作版本
我的要求是,如果由于消费者不可用(例如DB不可用)而导致消息处理失败,则消息保留在队列中或放回队列中(如果可能的话)。这是因为消息的顺序很重要,必须按照接收消息的相同顺序来消费消息。Java应用程序是单线程的。
@Override
public void onMessage(Message message)
{
try{
if(message instanceOf Textmessage)
{
}
:
:
throw new Exception("Test");// Just to test the retry
}
catch(Exception ex)
{
try
{
int temp = message.getIntProperty("JMSXDeliveryCount");
throw new RuntimeException("Redlivery attempted ");
// At this point, I am expecting JMS to put the message back into the queue.
// But it is actually put into the Bakout queue.
}
catch(JMSException ef)
{
String temp = ef.getMessage();
}
}
}
<property name="sessionTransacted" value="true" />
如果将消息放回队列中不可行,那么如何浏览消息、处理它,如果成功,如何拉出消息(这样它就被消费了,不再在队列中)?IBM provider for JMS支持此场景吗?
IBM MQ本地队列具有bothresh(1)
。
若要保留消息顺序,一种方法可能是作为回滚策略的一部分暂时停止消息侦听器。查看DefaultMessageListenerContainer
的Spring Boot文档,有一个Stop(Runnable callback)
方法。我已经尝试在回滚中使用它,如下所示。
为了确保我的侦听器是单线程的,我在DefaultJMSListenerContainerFactory
上设置了ContainerFactory.setConcurrency(“1”)
。
在我的侦听器中,我设置了ID
@JmsListener(destination = "DEV.QUEUE.2", containerFactory = "listenerTwoFactory", concurrency="1", id="listenerTwo")
JmsListenerEndpointRegistry reg = context.getBean(JmsListenerEndpointRegistry.class);
DefaultMessageListenerContainer mlc = (DefaultMessageListenerContainer) reg.getListenerContainer("listenerTwo");
retryCount = Integer.parseInt(msg.getStringProperty("JMSXDeliveryCount"));
if (retryCount < 5) {
throw new Exception("Rollback test "+retryCount);
}
//catch processing here and decide to rollback
mlc.stop(new ContainerTimedRestart(mlc,delay));
System.out.println("#### "+getClass().getName()+" Unable to process message.");
throw new Exception();
public class ContainerTimedRestart implements Runnable {
//Container instance to restart.
private DefaultMessageListenerContainer theMlc;
//Default delay before restart in mills.
private long theDelay = 5000L;
//Basic constructor for testing.
public ContainerTimedRestart(DefaultMessageListenerContainer mlc, long delay) {
theMlc = mlc;
theDelay = delay;
}
public void run(){
//Validate container instance.
try {
System.out.println("#### "+getClass().getName()+"Waiting for "+theDelay+" millis.");
Thread.sleep(theDelay);
System.out.println("#### "+getClass().getName()+"Restarting container.");
theMlc.start();
System.out.println("#### "+getClass().getName()+"Container started!");
} catch (InterruptedException ie) {
ie.printStackTrace();
//Further checks and ensure container is in correct state.
//Report errors.
}
}
我正在处理一个分支,例如需要删除表X中的一列,我添加了一个更改,它对该特定分支有好处,然后我切换到另一个分支,该分支仍然需要该列,并且该更改需要回滚。db在不同的分支之间有很多变化,比如这样的变化。 我为每个分支添加一个新的changelog xml,并将其包含在主changelog xml中。显然,当我切换到另一个分支时,前一个分支的changlog xml不再在工作区中,并且liquibase
问题内容: 我想运行自己的内部pypi服务器,以便在组织内分发鸡蛋。 我发现了一些项目,例如: http://pypi.python.org/pypi/EggBasket/ http://plone.org/products/plonesoftwarecenter 据我了解,pypi.python.org使用名为Cheese Shop的软件。 我的问题: 为什么我不能使用奶酪店本身?(我找不到它,
问题内容: 将内容添加到ListView时,我希望它自动向下滚动。 我正在使用SwiftUI 和a 作为控制器。新数据将追加到列表中。 当我将新数据追加到消息列表时,我希望列表向下滚动。但是,我必须手动向下滚动。 问题答案: 更新:在iOS 14中,现在有一种本机方式可以执行此操作。我正在这样做 对于iOS 13及以下版本,您可以尝试: 我发现翻转视图对我来说似乎很好。这将在底部启动ScrollV
它将打开WhatsApp,并将你带到特定的联系人,如果你已经保存,它将粘贴给定的文本,但它不会发送消息。 链接 他们正在访问通知以获取消息。我想知道他们是如何在没有打开应用程序的情况下在后台发送消息的。如果有人知道这个方法,请在这里分享。
之前的步骤,演示了默认的BasicWxHandler的行为是怎样的,现在,我们要自定义一个WxHandler了 新建一个类,继承BasicWxHandler @IocBean(create="init", name="wxHandler") public class DefaultWxHandler extends BasicWxHandler { @Inject protected Prop
问题内容: 考虑以下: 题: 我注意到该事务自动回滚,并且记录插入尝试失败。 如果我没有像上面一样提供错误处理程序或错误检查,是否安全,因为它从未执行过,因此在上述示例中似乎可以完成工作? 我认为事务会立即回滚并在发生错误时立即丢弃。 问题答案: 不,一旦发生错误,事务不会回滚。但是您可能正在使用应用此策略的客户端应用程序。 例如,如果您使用的是mysql命令行客户端,则它通常会在发生错误时停止执