如何在Websphere Liberty中修复远程ejb查找?

时间:2019-03-26 05:58:33

标签: ejb ejb-3.0 websphere-liberty ejb-3.1

我正在尝试访问在Websphere Liberty 18.0.0.3上部署的ejb

绑定位置是:java:global / ITSORemote / ITSORemoteEJB / HelloRemoteEJB!com.ibm.itso.ejbRemote.view.HelloRemoteEJBRemote

server.xml中的ORB配置是:

 <orb nameService="corbaname::<ipaddress>:2809" iiopEndpointRef="defaultIiopEndpoint">

   <iiopEndpoint host= id="defaultIiopEndpoint" iiopPort="2809">
   </iiopEndpoint>

    </orb>

我还在功能管理器中添加了ejbRemote-3.2

我有两种情况: 1。从在同一服务器上运行的客户机代码访问ejb-使用url 可以正常工作 java:global / ITSORemote / ITSORemoteEJB / HelloRemoteEJB!com.ibm.itso.ejbRemote.view.HelloRemoteEJBRemote 2。从在其他服务器上运行的客户端代码访问ejb-使用url无效 corbaname::( ipaddress):2809#ejb / global / ITSORemote / ITSORemoteEJB / HelloRemoteEJB!com.ibm.itso.ejbRemote.view.HelloRemoteEJBRemote

我正在使用以下代码进行查找:

package com.ibm.remoteaccess;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Hashtable;

import javax.ejb.EJB;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.rmi.PortableRemoteObject;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.ibm.itso.ejbRemote.view.HelloRemoteEJBRemote;

/**
 * Servlet implementation class RemoteAccess
 */
@WebServlet("/RemoteAccess")
public class RemoteAccess extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        PrintWriter out = response.getWriter();
        try {
            out.println("Hi");
            Context ctx = new InitialContext();
            Object ejbBusIntf = ctx.lookup("java:global/ITSORemote/ITSORemoteEJB/HelloRemoteEJB!com.ibm.itso.ejbRemote.view.HelloRemoteEJBRemote");
            HelloRemoteEJBRemote bean = (HelloRemoteEJBRemote)PortableRemoteObject.narrow(ejbBusIntf, HelloRemoteEJBRemote.class);
            out.println(bean.hello());
         }
         catch (NamingException e) { // Error getting the business interface
             out.println(e);
         }
    }

}

控制台中也没有引发任何错误。可能是什么问题?

1 个答案:

答案 0 :(得分:0)

开放自由中有一个功能接受测试(FAT),它可以从一个自由服务器到另一个自由服务器上的EJB查找远程EJB。具体的测试可以在这里找到:

https://github.com/OpenLiberty/open-liberty/blob/master/dev/com.ibm.ws.ejbcontainer.remote_fat/test-applications/RemoteClientWeb.war/src/com/ibm/ws/ejbcontainer/remote/client/web/RemoteTxAttrServlet.java

每个服务器进程都包含ejbRemote-3.2功能和iiopEndpoint配置(由于测试运行时两个端口都在同一主机上,因此端口不同)。

https://github.com/OpenLiberty/open-liberty/blob/master/dev/com.ibm.ws.ejbcontainer.remote_fat/publish/servers/com.ibm.ws.ejbcontainer.remote.fat.RemoteServerClient/server.xml

如果没有看到任何错误,则说明iiopEndpoint没有在客户端服务器中正确配置(因为没有它,ORB将无法启动)。例如,默认iiop端口为2809,并且如果两个服务器都在同一主机上,则它们不能同时使用该端口。将两个服务器都设置为相同的端口将导致ORB在其中一台服务器上无法正确启动,并且查找将失败。

跨服务器查找将使用corbaname,并且您指定的值似乎正确。