我正在尝试通过可执行的JBoss应用程序(本地而不是JBoss)连接到本地Java7.2上的远程EJB。
但是,我得到以下错误/异常:
java.lang.IllegalStateException: EJBCLIENT000025: No EJB receiver available for handling [appName:xx-xx, moduleName:xx-xx-business-impl, distinctName:] combination for invocation context org.jboss.ejb.client.EJBClientInvocationContext@14bc02d
at org.jboss.ejb.client.EJBClientContext.requireEJBReceiver(EJBClientContext.java:693)
at org.jboss.ejb.client.ReceiverInterceptor.handleInvocation(ReceiverInterceptor.java:116)
at org.jboss.ejb.client.EJBClientInvocationContext.sendRequest(EJBClientInvocationContext.java:183)
at org.jboss.ejb.client.EJBInvocationHandler.doInvoke(EJBInvocationHandler.java:177)
at org.jboss.ejb.client.EJBInvocationHandler.doInvoke(EJBInvocationHandler.java:161)
at org.jboss.ejb.client.EJBInvocationHandler.invoke(EJBInvocationHandler.java:124)
at com.sun.proxy.$Proxy0.getX(Unknown Source)
at com...ris.client.PACSServiceTest.main(PACSServiceTest.java:71)测试远程bean TestService及其实现在EAR中。
服务器类:
@Remote
public interface TestService {
public int getX();
}
@Stateless
@Remote(TestService.class)
public class TestServiceBean implements TestService{
@Override
public int getX() {
// TODO Auto-generated method stub
return 1111;
}
}客户代码:
final Hashtable jndiProperties = new Hashtable();
jndiProperties.put(Context.URL_PKG_PREFIXES, "org.jboss.ejb.client.naming");
jndiProperties.put(Context.INITIAL_CONTEXT_FACTORY, "org.jboss.naming.remote.client.InitialContextFactory");
jndiProperties.put(Context.PROVIDER_URL,"remote://localhost:4447");
String jndiName = "ejb:orbis-dicom/orbis-dicom-business-impl//TestServiceBean!"
+ TestService.class.getName();
logger.info(jndiName);
final Context context = new InitialContext(jndiProperties);
TestService service = (TestService) context.lookup(jndiName);
logger.info(service.getX());jboss client.properties:
remote.connectionprovider.create.options.org.xnio.Options.SSL_ENABLED=false
remote.connections=default
remote.connection.default.host=localhost
remote.connection.default.port =4447
remote.connection.default.connect.options.org.xnio.Options.SASL_POLICY_NOANONYMOUS=false
remote.connection.default.username=xx
remote.connection.default.password=x客户依赖关系:
+- org.jboss.spec.javax.transaction:jboss-transaction-api_1.1_spec:jar:1.
nal:runtime
+- org.jboss.spec.javax.ejb:jboss-ejb-api_3.1_spec:jar:1.0.2.Final:runtim
+- org.jboss:jboss-ejb-client:jar:1.0.16.Final:runtime
| +- org.jboss.marshalling:jboss-marshalling:jar:1.3.16.GA:runtime (vers
naged from 1.3.15.GA)
| \- org.jboss.logging:jboss-logging:jar:3.1.2.GA:runtime
+- org.jboss.xnio:xnio-api:jar:3.0.7.GA:runtime
+- org.jboss.xnio:xnio-nio:jar:3.0.7.GA:runtime
+- org.jboss.remoting3:jboss-remoting:jar:3.2.14.GA:runtime
+- org.jboss.sasl:jboss-sasl:jar:1.0.3.Final:runtime
+- org.jboss.marshalling:jboss-marshalling-river:jar:1.3.16.GA:runtime
+- org.jboss.as:jboss-as-naming:jar:7.2.0.Final:provided
| +- org.jboss:jboss-remote-naming:jar:1.0.5.Final:provided
| +- org.jboss.msc:jboss-msc:jar:1.0.4.GA:provided
| +- org.jboss.as:jboss-as-server:jar:7.2.0.Final:provided
| | +- org.jboss.as:jboss-as-controller:jar:7.2.0.Final:provided
| | | +- org.jboss.as:jboss-as-controller-client:jar:7.2.0.Final:provi
| | | \- org.jboss:staxmapper:jar:1.1.0.Final:provided
| | +- org.jboss.as:jboss-as-domain-http-interface:jar:7.2.0.Final:prov
| | | +- org.jboss.as:jboss-as-domain-management:jar:7.2.0.Final:provi
| | | | \- org.jboss:jboss-common-core:jar:2.2.17.GA:provided
| | | \- org.jboss.com.sun.httpserver:httpserver:jar:1.0.1.Final:provi
| | +- org.jboss.as:jboss-as-deployment-repository:jar:7.2.0.Final:prov
| | | \- org.jboss.as:jboss-as-protocol:jar:7.2.0.Final:provided
| | +- org.jboss.as:jboss-as-platform-mbean:jar:7.2.0.Final:provided
| | +- org.jboss.as:jboss-as-process-controller:jar:7.2.0.Final:provide
| | | \- system:jdk-tools:jar:jdk:system
| | +- org.jboss.as:jboss-as-remoting:jar:7.2.0.Final:provided
| | | \- org.jboss.as:jboss-as-network:jar:7.2.0.Final:provided
| | +- org.jboss.as:jboss-as-version:jar:7.2.0.Final:provided
| | +- org.jboss:jandex:jar:1.0.3.Final:provided
| | +- org.jboss:jboss-dmr:jar:1.1.6.Final:provided
| | +- org.jboss.invocation:jboss-invocation:jar:1.1.1.Final:provided
| | +- org.jboss.logmanager:jboss-logmanager:jar:1.4.0.Final:provided
| | +- org.jboss.logmanager:log4j-jboss-logmanager:jar:1.0.1.Final:prov
| | +- org.jboss.modules:jboss-modules:jar:1.2.0.CR1:provided
| | +- org.jboss.stdio:jboss-stdio:jar:1.0.1.GA:provided
| | +- org.jboss.threads:jboss-threads:jar:2.1.0.Final:provided
| | \- org.jboss:jboss-vfs:jar:3.1.0.Final:provided
| \- org.jboss.as:jboss-as-build-config:jar:7.2.0.Final:provided
\- log4j:log4j:jar:1.2.16:compile有什么想法吗?提前感谢!
发布于 2015-02-25 22:17:47
只要您想要访问“查找”远程EJB上的方法,就需要保持InitialContext引用(它不能被垃圾收集)。
发布于 2016-10-11 11:37:30
同样的问题困扰我好几天了。我用的是野生蝇9.0.2,但它的本质应该是一样的。将属性jboss.naming.client.ejb.context设置为false。
JBoss为远程查找提供了两种不同的方法:“远程命名”和“ejb”。这两种方法在https://docs.jboss.org/author/display/AS71/Remote+EJB+invocations+via+JNDI+-+EJB+client+API+or+remote-naming+project都得到了最好的解释。
您正在使用一种纯粹的“EJB”方法,在这种方法中,从EJB代理中查找的InitialContext不再有效(也就是说,它已关闭或gc‘’ed)。这就是“无EJB接收者”异常的含义。当属性jboss.naming.client.ejb.context为true时,它指示所有InitialContext调用都应使用InitialContext。但是,像前面提到的那样保持对InitialContext的引用并不是一个好主意。
解决方案是将jboss.naming.client.ejb.context设置为false,这将强制EJB调用由“远程命名”框架管理。为了使其工作,您需要类路径上的jboss-ejb-client.properties和jndi.properties文件(或以编程方式配置)。后者应包含以下属性:
java.naming.factory.initial=org.jboss.naming.remote.client.InitialContextFactory
java.naming.provider.url=remote://localhost:4447
jboss.naming.client.ejb.context=false考虑到这种设置,您甚至可以在查找EJB之后立即调用InitialContext.close() (以防您不能等待它被自动gc‘’ed)。
发布于 2014-05-20 02:15:07
在客户端代码中添加以下设置: jndiProperties.put("jboss.naming.client.ejb.context",true);
https://stackoverflow.com/questions/21748172
复制相似问题