0

我正在通过我的独立应用程序发送一条消息,该应用程序使用 EJB MDB 与我在 JBOSS 服务器上运行的其他应用程序服务器进行通信。我的应用程序服务器连接到 MSSQL 服务器。在某些情况下,应用程序服务器端与数据库的连接丢失,我们收到以下错误 -

Connection is reset.

稍后,当我尝试发送消息时,我的独立 EJB MDB 日志中没有任何错误,并且该进程停止执行。我在应用程序服务器端日志上收到错误日志,但相同的日志没有传播到我的 EJB MDB 错误日志。

根据我的理解,当 db 连接丢失时,jboss 容器中的所有 ejb bean 也会失效。(我可能错了,我是 EJB 新手)。

我尝试在用于发送消息的代码中实现以下代码 -

QueueConnection qcon = null;
   @PostConstruct
    public void initialize() {
        System.out.println("In PostConstruct");
        try {
            qcon = qconFactory.createQueueConnection();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }


    @PreDestroy
    public void releaseResources() {
        System.out.println("In PreDestroy");
        try {
            if(qcon != null)
            {
                qcon.close();
            }
            if(qcon== null){
                throw new Exception(" new exception occured.");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

我的印象是,当我们的数据库连接丢失时(因为我们正在创建 bean 并为消息建立连接),Queueconnection 对象将被取消。但这似乎不起作用。

4

1 回答 1

0

我确实找到了一种在发送消息后回调我的应用程序的方法。我使用了一个单独的临时队列并使用 setJMSReplyTo 方法来设置回复目的地。可以从此 链接获得更多信息。希望这对其他人有帮助。

于 2018-05-10T07:54:27.503 回答