Java 已部署EJB的JNDI查找失败

Java 已部署EJB的JNDI查找失败,java,jakarta-ee,netbeans,deployment,glassfish,Java,Jakarta Ee,Netbeans,Deployment,Glassfish,我编写了一个EJB模块,并将其部署到GlassFish。然后,我编写了一个Enterprise应用程序客户端,并将其部署到GlassFish 无状态bean的代码: package remote; @Stateless @Remote(IPersonEJB.class) @LocalBean public class PersonEJB implements IPersonEJB{ @PersistenceContext(unitName = "JobsPU") private Entity

我编写了一个EJB模块,并将其部署到GlassFish。然后,我编写了一个Enterprise应用程序客户端,并将其部署到GlassFish

无状态bean的代码:

package remote;

@Stateless
@Remote(IPersonEJB.class)
@LocalBean
public class PersonEJB implements IPersonEJB{

@PersistenceContext(unitName = "JobsPU")
private EntityManager em;

@Override
public Person giveJobToPerson(Job job, Person person) {
    em.persist(person);
    em.flush();
    job.setEmployeeID(person.getId());
    em.persist(job);
    return person;
}

// Add business logic below. (Right-click in editor and choose
// "Insert Code > Add Business Method")

@Override
public Person getPerson(Long id) {
    return em.find(Person.class, id);
}
}
已部署EBJ的Persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
  <persistence-unit name="JobsPU" transaction-type="JTA">
    <jta-data-source>jdbc/__TimerPool</jta-data-source>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>
    <properties>
      <property name="eclipselink.logging.level" value="INFO"/>
      <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
      <property name="eclipselink.target-database" value="Derby"/>
    </properties>
  </persistence-unit>
</persistence>
如果我尝试运行客户端,会出现以下异常:

Warning: C:\Users\Paolo\Documents\NetBeansProjects\JobsClient\dist\gfdeploy\JobsClient does not exist.
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.glassfish.appclient.client.acc.AppClientContainer.launch(AppClientContainer.java:446)
    at org.glassfish.appclient.client.AppClientFacade.main(AppClientFacade.java:166)
Caused by: javax.naming.NamingException: Lookup failed for 'java:global/Jobs/IPersonEJB!remote.IPersonEJB' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.url.pkgs=com.sun.enterprise.naming, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl} [Root exception is javax.naming.NameNotFoundException: IPersonEJB!remote.IPersonEJB not found]
    at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:491)
    at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:438)
    at javax.naming.InitialContext.lookup(InitialContext.java:417)
    at jobsclient.Main.main(Main.java:28)
    ... 6 more
Caused by: javax.naming.NameNotFoundException: IPersonEJB!remote.IPersonEJB not found
    at com.sun.enterprise.naming.impl.TransientContext.doLookup(TransientContext.java:237)
    at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:204)
    at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:208)
    at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:208)
    at com.sun.enterprise.naming.impl.SerialContextProviderImpl.lookup(SerialContextProviderImpl.java:66)
    at com.sun.enterprise.naming.impl.RemoteSerialContextProviderImpl.lookup(RemoteSerialContextProviderImpl.java:109)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie.dispatchToMethod(ReflectiveTie.java:143)
    at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie._invoke(ReflectiveTie.java:173)
    at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatchToServant(ServerRequestDispatcherImpl.java:528)
    at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatch(ServerRequestDispatcherImpl.java:199)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequestRequest(MessageMediatorImpl.java:1549)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:1425)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleInput(MessageMediatorImpl.java:930)
    at com.sun.corba.ee.impl.protocol.giopmsgheaders.RequestMessage_1_2.callback(RequestMessage_1_2.java:213)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:694)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.dispatch(MessageMediatorImpl.java:496)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.doWork(MessageMediatorImpl.java:2222)
    at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.performWork(ThreadPoolImpl.java:497)
    at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.run(ThreadPoolImpl.java:540)
Java Result: 1
run:
BUILD SUCCESSFUL (total time: 9 seconds)
我试图找到一个解决方案,我在Stackoverflow上读到了一些其他问题,比如这个,但我无法解决我的问题。我想这是JNDI名称的问题吧?但是我在任何地方都找不到它部署时使用的名称(我在glassfish管理控制台中查找了所有地方),我认为名称字符串的格式是正确的(根据我阅读的指南)


我使用netbeans的部署功能部署了这两个应用程序。也许我丢失了一些配置文件(ejb.xml或其他)?

我刚刚发现了错误:我在查找远程接口,而不是bean本身

    IPersonEJB personEJB = (IPersonEJB) ctx.lookup("java:global/Jobs/IPersonEJB!remote.IPersonEJB");
应该是

    IPersonEJB personEJB = (IPersonEJB) ctx.lookup("java:global/Jobs/PersonEJB!remote.IPersonEJB");
    IPersonEJB personEJB = (IPersonEJB) ctx.lookup("java:global/Jobs/PersonEJB!remote.IPersonEJB");