http://wxg6203.iteye.com/blog/680830

最近因为工作需要开始学习Ejb3,遇到了一个让我很郁闷的事情,做一下小小的总结——小心new InitialContext()。

在做客户端的时候,发现连接服务器,搜索数据库,然后返回结果集。每一次执行的时候,第一次总要花更多的时间,之后每一次操作时间就要快很多了。期间找了很多方法,都行不通。一开始以为是Ejb服务器建立服务消耗时间,后来觉得不对,因为Jboss启动的时候,已经将服务启动了。经过一周的排查,终于发现原来是因为new InitialContext()消耗了大量的时间,之后的lookup()方法也会消耗一定的时间。其中,在网络状态良好的情况下,每一次new InitialContext()方法花费大概100毫秒到200毫秒之间,而每一次lookup()大概要花10毫秒到30毫秒之间。因此,决定对代码进行优化,创建了EJBHomeFactory工具类,使用到了单例模式,欢迎大家指教。以下为该类代码:

Java代码 
import javax.naming.InitialContext;   
import javax.naming.NamingException;   
  
import com.cithinc.util.Tool;   
  
public class EJBHomeFactory {   
    private static EJBHomeFactory instance;   
    private InitialContext context;   
  
    private EJBHomeFactory() throws NamingException {   
        context = Tool.getInitialContext();   
    }   
  
    public static EJBHomeFactory getInstance() throws NamingException {   
        if (instance == null) {   
            instance = new EJBHomeFactory();   
        }   
        return instance;   
    }   
  
    public Object lookup(String jndiName) throws NamingException {   
        Object obj = new Object();   
        obj = context.lookup(jndiName);   
        return obj;   
    }   
}

import javax.naming.InitialContext; 
import javax.naming.NamingException;

import com.cithinc.util.Tool;

public class EJBHomeFactory { 
private static EJBHomeFactory instance; 
private InitialContext context;

private EJBHomeFactory() throws NamingException { 
context = Tool.getInitialContext(); 
}

public static EJBHomeFactory getInstance() throws NamingException { 
if (instance == null) { 
instance = new EJBHomeFactory(); 

return instance; 
}

public Object lookup(String jndiName) throws NamingException { 
Object obj = new Object(); 
obj = context.lookup(jndiName); 
return obj; 

}

其中,Tool.java的文件内容如下:

Java代码 
import java.util.Hashtable;   
  
import javax.naming.Context;   
import javax.naming.InitialContext;   
import javax.naming.NamingException;   
  
public class Tool {   
    @SuppressWarnings("unchecked")   
    public static InitialContext getInitialContext() throws NamingException {   
        Hashtable environment = new Hashtable();   
        environment.put(Context.INITIAL_CONTEXT_FACTORY,"org.jnp.interfaces.NamingContextFactory");   
        environment.put(Context.URL_PKG_PREFIXES,"org.jboss.naming:org.jnp.interfaces");   
        environment.put(Context.PROVIDER_URL, "jnp://127.0.0.1:1099");   
        return new InitialContext(environment);   
    }   
}

import java.util.Hashtable;

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

public class Tool { 
@SuppressWarnings("unchecked") 
public static InitialContext getInitialContext() throws NamingException { 
Hashtable environment = new Hashtable(); 
environment.put(Context.INITIAL_CONTEXT_FACTORY,"org.jnp.interfaces.NamingContextFactory"); 
environment.put(Context.URL_PKG_PREFIXES,"org.jboss.naming:org.jnp.interfaces"); 
environment.put(Context.PROVIDER_URL, "jnp://127.0.0.1:1099"); 
return new InitialContext(environment); 

}

然后这样调用:

Java代码 
EJBHomeFactory f = EJBHomeFactory.getInstance();   
Object o = f.lookup(remote);

EJBHomeFactory f = EJBHomeFactory.getInstance(); 
Object o = f.lookup(remote);

这样就可以保证只初始化一次上下文实例,节省大量的时间。

分享到:  
评论
2 楼 surpassno 2013-08-29  
1 楼 ybzshizds 2010-08-06  
这种用工厂模式解决的办法其实还是有一个问题,就是ejb容器重启后,客户端应该也要重新去new InitialContext,否则用原来的InitialContext去lookup,会抛出错。

想想后,我是这样去解决的。

为每个ejbhome,新建一个ejbHelper类

如:

  1. package com.company.vas.ejb.helper;
  2. import java.rmi.RemoteException;
  3. import javax.ejb.CreateException;
  4. import javax.naming.NamingException;
  5. import com.company.util.Log;
  6. import com.company.vas.ejb.Invoice;
  7. import com.company.vas.ejb.home.InvoiceHome;
  8. public class InvoiceHelper {
  9. private static final String CLASS_NAME = "InvoiceHelpler";
  10. private static InvoiceHome home;
  11. public static Invoice getInvoice() {
  12. try {
  13. if (home == null) {
  14. home = (InvoiceHome) EjbGetter.getEJBHome(
  15. IInvoice.JNDI_NAME, InvoiceHome.class);
  16. }
  17. return home.create();
  18. } catch (NamingException e) {
  19. Log.error(CLASS_NAME, "getInvoice()", e.getMessage());
  20. home = null;
  21. } catch (RemoteException e) {
  22. Log.error(CLASS_NAME, "getInvoice()", e.getMessage());
  23. home = null;
  24. } catch (CreateException e) {
  25. Log.error(CLASS_NAME, "getInvoice()", e.getMessage());
  26. home = null;
  27. }
  28. return null;
  29. }
  30. }
  31. package com.company.vas.ejb.helper;
  32. import java.util.Properties;
  33. import javax.ejb.EJBHome;
  34. import javax.naming.Context;
  35. import javax.naming.InitialContext;
  36. import javax.naming.NamingException;
  37. public class EjbGetter {
  38. public static EJBHome getEJBHome(String service_jndiname, Class homeInterface) throws NamingException{
  39. Properties env = new Properties();
  40. env.put(Context.INITIAL_CONTEXT_FACTORY, "org.jnp.interfaces.NamingContextFactory");
  41. env.put(Context.PROVIDER_URL, "192.168.60.120:1099");
  42. env.put("java.naming.factory.url.pkgs", "org.jboss.naming:org.jnp.interfaces");
  43. Context ic = new InitialContext(env);
  44. EJBHome ejbHome = (EJBHome)javax.rmi.PortableRemoteObject.narrow(ic.lookup(service_jndiname), homeInterface);
  45. return ejbHome;
  46. }
  47. }

InitialContext和lookup的更多相关文章

  1. InitialContext和lookup(转)

    原文地址:http://wxg6203.iteye.com/blog/680830 最近因为工作需要开始学习Ejb3,遇到了一个让我很郁闷的事情,做一下小小的总结——小心new InitialCont ...

  2. InitialContext与lookup

    Context initial = new InitialContext(); Object objref = initial.lookup("java:comp/env/ejb/Simpl ...

  3. Jboss7.1 local EJB lookup problem

    We are trying to lookup for an Local EJB in JBoss7.1, but we get an ClassCast Exception. This local ...

  4. Class loading in JBoss AS 7--官方文档

    Class loading in AS7 is considerably different to previous versions of JBoss AS. Class loading is ba ...

  5. 浅谈JNDI的使用

    原文:http://www.weicoop.com/web/article/52.html 关于什么是JNDI的概念这里不做解释,本文作为初学者根据所了解到内容做些总结,主要内容如下: 1.JNDI使 ...

  6. JNDI support differences between Tibco EMS and ActiveMQ

    Introduction Recently our team was working on Veracity Quick Start sprint, when I was trying to migr ...

  7. 再说JNDI

    说到JNDI,即熟悉又陌生,熟悉在常常使用,如EJB3.0中的@EJB注入,底层实现即是JNDI的方式:喜闻乐见的: Context ctx=new InitialContext(); Object ...

  8. java_web学习(12)JDBC

    数据持久化       持久化(persistence):把数据保存到可掉电式存储设备中以供之后使用.大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以”固化”,而持久化的 ...

  9. Java命名和目录接口——JNDI

    JNDI即Java命名和目录接口(JavaNaming and Directory Interface),它属于J2EE规范范畴,是J2EE的核心技术之一,提供了一组接口.类和关于命名空间的概念.JD ...

随机推荐

  1. etcd集群日常维护

    配置文件和启动参数说明 命令行 | 配置文件 | 说明 data-dir | ETCD_DATA_DIR | 指定节点的数据存储目录,包括节点ID,集群ID,集群初始化配置,Snapshot文件,若未 ...

  2. 对类中的成员函数的定义和声明最后添加一个const是什么意思?

    1.const修饰的成员函数只能调用const修饰的成员函数,且不能修改数据成员变量的值. 2.const修饰的类对象只能调用const修饰的成员函数. 3.const修饰的类对象可以调用非const ...

  3. github 丢失的本地提交

    open git bash git reflog git reset xxxxxxx

  4. Java中hashcode的理解

    Java中hashcode的理解 原文链接http://blog.csdn.net/chinayuan/article/details/3345559 怎样理解hashCode的作用: 以 java. ...

  5. ES翻译之Function Score Query

    Function Score Query 原文链接 function_score允许你修改通过查询获取文档的分数,很有用处,score function是计算昂贵的,以及在过滤一系列文档上计算分数是高 ...

  6. 转: Servlet-jsp从入门到精通 1~5

    评注: 来自简书,内容很简要. http://www.jianshu.com/p/d718a5f4a850 (一) http://www.jianshu.com/p/06efc32c10cf   (二 ...

  7. FizzBuzz and Fibonacci优化

    ***************************************转载请注明出处:http://blog.csdn.net/lttree************************** ...

  8. 【Android工具类】怎样保证Android与server的DES加密保持一致

    转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992 在我们的应用程序涉及到比較敏感的数据的时候,我们一般会对数据进行简单的加密.在与server之间的数据交互中 ...

  9. 字典树-HDOJ-1247-Hat’s Words

    Hat's Words Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Tota ...

  10. 【VBA】复制单元格数据有效性

    单元格内设置了有效性,通过VBA怎么去复制呢?代码如下: Public Sub 复制单元格批注() Dim range1 As range Dim range2 As range '清除G列 Colu ...