#ejb #wildfly #jndi
#ejb #wildfly #jndi
Вопрос:
У меня возникли проблемы с Wildfly 15.0.0 из-за того, что он не создает JNDI для EJB, который реализует как локальные, так и удаленные интерфейсы. Мои классы следующие:
Локальный интерфейс:
@Local
public interface BlockingManagerRemote{
}
Удаленный интерфейс:
@Remote
public interface BlockingManagerLocal{
}
реализация:
@Remote({BlockingManagerRemote.class})
@Local({BlockingManagerLocal.class})
@Stateless
public class BlockingManager
implements BlockingManagerRemote, BlockingManagerLocal {
}
Сначала я получаю следующее сообщение:
2019-03-13 12:09:57,459 INFO [org.jboss.as.ejb3.deployment] (MSC service thread 1-3) WFLYEJB0111: No jndi bindings will be created for EJB BlockingManager since no views are exposed
И при попытке внедрить этот EJB в другой класс следующим образом:
@Remote({BusinessUserManagerRemote.class})
@Local({BusinessUserManagerLocal.class})
@Stateless
public class BusinessUserManager
implements BusinessUserManagerLocal, BusinessUserManagerRemote {
@EJB
private BlockingManagerLocal blockingManager;
}
Я получаю это исключение:
2019-03-13 12:09:58,469 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-1) MSC000001: Failed to start service jboss.deployment.subunit."mpaymentapp-ear.ear"."mpaymentapp-service-1.0.3-SNAPSHOT.jar".INSTALL: org.jboss.msc.service.StartException in service jboss.deployment.subunit."mpaymentapp-ear.ear"."mpaymentapp-service-1.0.3-SNAPSHOT.jar".INSTALL: WFLYSRV0153: Failed to process phase INSTALL of subdeployment "mpaymentapp-service-1.0.3-SNAPSHOT.jar" of deployment "mpaymentapp-ear.ear"
at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:151)
at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1738)
at org.jboss.msc.service.ServiceControllerImpl$StartTask.execute(ServiceControllerImpl.java:1700)
at org.jboss.msc.service.ServiceControllerImpl$ControllerTask.run(ServiceControllerImpl.java:1558)
at org.jboss.threads.ContextClassLoaderSavingRunnable.run(ContextClassLoaderSavingRunnable.java:35)
at org.jboss.threads.EnhancedQueueExecutor.safeRun(EnhancedQueueExecutor.java:1985)
at org.jboss.threads.EnhancedQueueExecutor$ThreadBody.doRunTask(EnhancedQueueExecutor.java:1487)
at org.jboss.threads.EnhancedQueueExecutor$ThreadBody.run(EnhancedQueueExecutor.java:1364)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.jboss.as.server.deployment.DeploymentUnitProcessingException: WFLYEE0052: Failed to install component BusinessUserManager
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor.deploy(ComponentInstallProcessor.java:109)
at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:144)
... 8 more
Caused by: org.jboss.as.server.deployment.DeploymentUnitProcessingException: WFLYEJB0406: No EJB found with interface of type 'com.cit.mpaymentapp.common.blocking.BlockingManagerLocal' for binding com.cit.mpaymentapp.service.registration.BusinessUserManager/blockingManager
at org.jboss.as.ejb3.deployment.processors.EjbInjectionSource.getResourceValue(EjbInjectionSource.java:90)
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor.processBindings(ComponentInstallProcessor.java:263)
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor.access$000(ComponentInstallProcessor.java:80)
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor$1.handle(ComponentInstallProcessor.java:215)
at org.jboss.as.ee.component.ClassDescriptionTraversal.run(ClassDescriptionTraversal.java:54)
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor.deployComponent(ComponentInstallProcessor.java:218)
at org.jboss.as.ee.component.deployers.ComponentInstallProcessor.deploy(ComponentInstallProcessor.java:101)
... 9 more
Тот же код работал над JBOSS EAP6. Почему Wildfly не распознает локальный интерфейс BlockingManagerLocal
?
Комментарии:
1. В вашем примере у вас есть @Local в классе BlockingManagerRemote, это просто сообщение об ошибке здесь или это также неправильно в вашем коде? Я предполагаю, что в ваших интерфейсах действительно перечислены некоторые методы?
2. Да, аннотация @Local тоже есть в интерфейсе. Оба интерфейса содержат методы, но я опустил их в вопросе.
3. Пожалуйста, покажите свой application.xml
4. Как насчет моего комментария о том, что вы разместили @Local на своем удаленном компьютере и наоборот?
Ответ №1:
Я думаю, вам следует реализовать свои интерфейсы как простые интерфейсы Java и добавить аннотацию @LocalBean вместо @Local в вашу реализацию bean.
Следует избегать удаленных EJBS. Я рекомендую вместо этого использовать интерфейсы Rest.