【问题标题】:Naming Context stop working after idle time JBoss EAP 6.4.0命名上下文在空闲时间后停止工作 JBoss EAP 6.4.0
【发布时间】:2016-08-23 12:24:17
【问题描述】:

我正在使用 JBoss EAP 6.4 来部署 EJB ear 文件。一切正常,但如果 Swing 应用程序空闲一段时间(1 小时左右),然后尝试从 Swing 客户端访问任何功能,客户端就会崩溃,并出现以下异常:

javax.naming.NamingException: Unable to invoke lookup, status=WAITING
     at org.jboss.naming.remote.protocol.v1.Protocol$1.execute(Protocol.java:98)
     at org.jboss.naming.remote.protocol.v1.RemoteNamingStoreV1.lookup(RemoteNamingStoreV1.java:95)
     at org.jboss.naming.remote.client.HaRemoteNamingStore$1.operation(HaRemoteNamingStore.java:275)
     at org.jboss.naming.remote.client.HaRemoteNamingStore.namingOperation(HaRemoteNamingStore.java:132)
     at org.jboss.naming.remote.client.HaRemoteNamingStore.lookup(HaRemoteNamingStore.java:271)
     at org.jboss.naming.remote.client.RemoteContext.lookupInternal(RemoteContext.java:104)
     at org.jboss.naming.remote.client.RemoteContext.lookup(RemoteContext.java:93)
     at org.jboss.naming.remote.client.RemoteContext.lookup(RemoteContext.java:146)
     at javax.naming.InitialContext.lookup(Unknown Source)

它无法在客户端使用缓存的上下文解析 jndi。

使用以下属性在客户端创建的上下文:

    table.put("remote.connection.one.connect.options.org.xnio.Options.SASL_POLICY_NOPLAINTEXT", "false");
                    table.put("remote.connection.one.connect.options.org.xnio.Options.SASL_DISALLOWED_MECHANISMS", "JBOSS-LOCAL-USER");

table.put("remote.clusters", "ejb");
                    table.put("remote.cluster.ejb.connect.options.org.xnio.Options.SASL_POLICY_NOPLAINTEXT", "false");
table.put(Context.URL_PKG_PREFIXES, "org.jboss.ejb.client.naming");
table.put("jboss.naming.client.ejb.context", true);
                    table.put("jboss.naming.client.connect.options.org.xnio.Options.SASL_POLICY_NOPLAINTEXT", "false");
    table.put( Context.SECURITY_PRINCIPAL, System.getProperty( Context.SECURITY_PRINCIPAL));
    table.put( Context.SECURITY_CREDENTIALS, System.getProperty( Context.SECURITY_CREDENTIALS));
                    table.put("jboss.naming.client.remote.connectionprovider.create.options.org.xnio.Options.SSL_ENABLED","true");
                    table.put("jboss.naming.client.connect.options.org.xnio.Options.SSL_STARTTLS","true");
    table.put("jboss.naming.client.connect.timeout", "3000000");
    table.put( Context.PROVIDER_URL,PROVIDER_URL);

    context = new javax.naming.InitialContext( table); 

请帮助我了解为什么在空闲时间后无法查找上下文?

【问题讨论】:

  • 尝试每次都创建上下文,第二次完成后需要关闭上下文。不要重复使用代理。
  • 能否请您提供有关“不要重复使用代理”的更多详细信息?也不会影响性能吗?
  • 如果手动配置 JBoss 客户端属性会有问题吗?由于现有的应用程序架构,我们不能每次都重新创建上下文。大多数情况下,上下文会在理想状态 60 分钟后停止响应。

标签: java jakarta-ee jboss jboss7.x


【解决方案1】:

我终于找到了解决方案。在 JBoss EAP 6.4 中,使用旧的 JNDI 方法会产生问题,并且不支持 HeartBeat_Interval 等 JBoss 功能。

在 Jboss 中查找的最佳方法是使用 EJB 客户端查找方法。这解决了与崩溃等相关的所有问题。 https://docs.jboss.org/author/display/AS71/Remote+EJB+invocations+via+JNDI+-+EJB+client+API+or+remote-naming+project

【讨论】:

    猜你喜欢
    • 2018-04-27
    • 2018-12-09
    • 1970-01-01
    • 2020-11-19
    • 1970-01-01
    • 2012-05-01
    • 1970-01-01
    • 2017-05-27
    • 1970-01-01
    相关资源
    最近更新 更多