WebLogic11g-EJB部署

一.Weblogic11g部署EJB

weblogic部署ejb可以通过jar、ear方式,两种部署ejb方式的步骤都是一致的。
1.启动domain,并登录控制台

2.选择“部署”->“安装”,如下图所示:

3.选择ejb程序(这里以jar方式为例),选择ejb-service.jar,如图所示:

4.选择部署的目标,注意这里选择的是AdminServer,如图所示:

5.继续下一步,直到完成即可。部署成功之后,如图所示:

二.查看weblogic的jndi树

        可以看到类型为EJB,状态为活动。至此ejb应用已经部署成功,如何查看ejb的jndi呢?往下看。

查看weblogic的jndi树:
        选择“服务器”->“AdminServer”->“配置”->“一般信息”->“查看JNDI树”,如图所示:

        点击上图的链接,打开新的页面,展现jndi的树结构,如下图所示:

        我们在jndi的树结构中找到ejb应用程序的jndi(例子中有两个remote的ejb,分别是SessionEJB、SwapEJBBean,客户端调用时,需要使用右栏的“绑定名”作为jndi的名称,代码如下:

package example.ejb;

import java.util.Properties;

import javax.naming.Context;
import javax.naming.InitialContext;

public class TestWebLogicEJB {

    public static void main(String[] args) throws Exception {
        Properties properties = new Properties();
        properties.setProperty(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
        properties.setProperty(Context.PROVIDER_URL, "t3://localhost:7001");
        properties.setProperty(Context.SECURITY_PRINCIPAL, "weblogic");
        properties.setProperty(Context.SECURITY_CREDENTIALS, "weblogic123");

        Context context = new InitialContext(properties);
        SessionEJB session = (SessionEJB) context.lookup("SessionEJB#example.ejb.SessionEJB");
        session.addUser("test1");
        System.out.println(session.getUsers());
        session.addUser("test2");
        System.out.println(session.getUsers());

        SwapEJB swap = (SwapEJB) context.lookup("SwapEJBBean#example.ejb.SwapEJB");
        System.out.println(swap.invoke("test"));
    }
}

        上面代码分别调用了两个remote的ejb服务。注意点:context.lookup,lookup需要制定jndi的名称,这里使用前面介绍的jndi绑定名。
        weblogic11g是支持ejb3的,可以直接使用注解来定义ejb服务了。而不像以前还要创建weblogic-ejb-jar.xml文件来定义。
开发ejb3的程序步骤如下:
1.定义接口(这里不是必须):

package example.ejb;

public interface SwapEJB {
	public abstract String invoke(String request);
}

2.定义ejb的bean(这里以stateless为例):

package example.ejb;

import javax.ejb.Remote;
import javax.ejb.Stateless;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

@Stateless(mappedName = "SwapEJBBean")
@Remote({SwapEJB.class})
public class SwapEJBBean implements SwapEJB {
	private static final Log log = LogFactory.getLog(SwapEJBBean.class);
	@Override
	public String invoke(String request) {
		log.info("request=" + request);
		return "remote response=" + request;
	}
}

        部署到weblogic下面,需要指定mappedName。

扫描二维码关注公众号,回复: 478613 查看本文章

        ejb以jar的方式部署存在一些弊端,如果依赖很多第三方库,就需要增加到weblogic的classpath中。有两种方式(建议第一种方式):
1.weblogic11g对于domain依赖的第三方库,可以直接添加到domain下面的lib文件夹中。如我的lib位置:
C:\Oracle\user_projects\domains\base_domain\lib,weblogic启动的时候,会把这个文件夹下面的jar追加到启动脚本的classpath后面。

2.手动编辑startWebLogic.cmd,增加第三方库的jar路径到classpath中。

如果以ear部署就方便许多,部署方式没有任何差别,这里不介绍了。

三.调用部署好的EJB服务

        在Eclipse中调用刚刚部署好的EJB服务,验证是否OK。

        运行结果正确,说明部署与调用都OK。

说明:直接从http://dead-knight.iteye.com/blog/1946912下载的源代码,加载到Eclipse中运行,由于Weblogic、JDK版本不同,遇到了如下问题。

1.加载到工程中报错

        选中工程,右击选择Properties,点击“Targeted Runtimes”,将会看所有的Weblogic的运行环境。可以看到Oracle Weblogic Server 11gR1(10.3.5)。由于我机装的是Weblogic10.3.2,所以需新增一个Targeted Runtimes。点击“New”按钮,弹出如下对话框。

        选择和我本机的Weblogic一样的10.3.2版本,点“Next”。

        选择本机的Weblogic10.3的home目录,点击“Finish”回到Targeted Runtimes窗口,选择“Oracle Weblogic Server 11gR1(10.3.2)即可”。

2.运行TestWebLogicEJB.java报java.lang.NoClassDefFoundError: weblogic/kernel/KernelStatus错误处理

        a.在EJB项目的构建路径中删除weblogic system libraries类库;
        b.添加<SERVER_HOME>\wlserver_10.3\server\lib\wlclient.jar至构建路径中。

3.运行TestWebLogicEJB.java报unsupported classversion 错误处理

Exception in thread "Main Thread" javax.naming.CommunicationException [Root exception is weblogic.rjvm.PeerGoneException: ; nested exception is: 
	weblogic.utils.NestedException: java.lang.UnsupportedClassVersionError: javax/ejb/EJBException : unsupported classversion 51.0]
	at weblogic.jndi.internal.ExceptionTranslator.toNamingException(ExceptionTranslator.java:74)
	at weblogic.jndi.internal.WLContextImpl.translateException(WLContextImpl.java:452)
	at weblogic.jndi.internal.WLContextImpl.lookup(WLContextImpl.java:408)
	at weblogic.jndi.internal.WLContextImpl.lookup(WLContextImpl.java:393)
	at javax.naming.InitialContext.lookup(InitialContext.java:392)
	at example.ejb.TestWebLogicEJB.main(TestWebLogicEJB.java:18)

        原因是其lib下的javax.ejb-api.jar包是JDK1.7编译的,而我的JDK版本是JDK1.6的。详细排查方法见:http://bijian1013.iteye.com/admin/blogs/2222515,此处解决方法,由于工程本身不依赖javax.ejb-api.jar包,将javax.ejb-api.jar包从ejb-service工程中删除即可。

附Eclipse下打jar、ear包: http://bijian1013.iteye.com/blog/2233746

文章来源:http://dead-knight.iteye.com/blog/1946912

猜你喜欢

转载自bijian1013.iteye.com/blog/2233733