【问题标题】:I'm getting javax.naming.OperationNotSupportedException when trying to bind dbcp's BasicDataSource尝试绑定 dbcp 的 BasicDataSource 时出现 javax.naming.OperationNotSupportedException
【发布时间】:2014-06-19 19:42:27
【问题描述】:

我正在使用 Apache 的 commons DBCP 1.4 版本的 Jar。我正在关注通过 fscontex 绑定 BasicDataSource 的 JNDI 示例。如以下链接http://commons.apache.org/proper/commons-dbcp/guide/jndi-howto.html提供的代码所示。

我编写了类似的独立代码,但出现以下错误 “javax.naming.OperationNotSupportedException:只能绑定引用或可引用对象”。根据我的 kmowledge,任何想要被引用的对象都必须实现 javax.naming.Referenceable 接口并定义 getReference 方法。我不确定 BasicDataSource 是否这样做?

这是我使用的代码。

import java.sql.Connection;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
import org.apache.commons.dbcp.BasicDataSource;

public class DBCPTest {

public static void main(String[] args) {
    try {
        System.setProperty(Context.INITIAL_CONTEXT_FACTORY,
                "com.sun.jndi.fscontext.RefFSContextFactory");
        System.setProperty(Context.PROVIDER_URL, "file:///F:/JNDI/");
        InitialContext ic = new InitialContext();

        // Construct BasicDataSource
        BasicDataSource bds = new BasicDataSource();
        bds.setDriverClassName("org.apache.commons.dbcp2.TesterDriver");
        bds.setUrl("jdbc:apache:commons:testdriver");
        bds.setUsername("username");
        bds.setPassword("password");

        ic.rebind("jdbc/basic", bds);

        // Use
        InitialContext ic2 = new InitialContext();
        DataSource ds = (DataSource) ic2.lookup("jdbc/basic");

        Connection conn = ds.getConnection();
        conn.close();

    } catch (Exception e) {
        e.printStackTrace();
    }
}
}

这是我的类路径中的 JAR 列表

  • commons-dbcp-1.4.jar
  • commons-ppol-1.6.jar
  • fscontext.jar
  • providerutil.jar
  • jndi.jar

感谢任何有关解决此问题或指出我做错了什么的见解。

谢谢 厘米

【问题讨论】:

  • 文件系统上是否存在“F:/JNDI/”?
  • 是的,该目录确实存在于文件系统上。当我查看 BasicDataSource 的 api 时,它没有实现 javax.naming.Referenceable 接口。这就是原因,我猜它会抛出这个错误。

标签: java jndi apache-commons-dbcp


【解决方案1】:

浏览网页后,我确实找到了一种通过基于文件的上下文绑定 BasicDataSource 的方法。我使用了以下链接提供的示例

http://www.massapi.com/class/javax/naming/StringRefAddr.java.html

System.setProperty(Context.INITIAL_CONTEXT_FACTORY,
            "com.sun.jndi.fscontext.RefFSContextFactory");
    System.setProperty(Context.PROVIDER_URL, "file:///F:/JNDI/");

    Reference ref = new Reference("javax.sql.DataSource","org.apache.commons.dbcp.BasicDataSourceFactory", null);
    ref.add(new StringRefAddr("driverClassName","com.ibm.db2.jcc.DB2Driver");
    ref.add(new StringRefAddr("url","jdbc:db2://myhost.example.com:port/dbname");
    ref.add(new StringRefAddr("password", "SomePassord");
    ref.add(new StringRefAddr("username", "myUser");

    ref.add(new StringRefAddr("maxActive","100"));
    ref.add(new StringRefAddr("maxWait", "10000"));
    ref.add(new StringRefAddr("maxIdle", "10"));
    ref.add(new StringRefAddr("minIdle", "5"));

    ref.add(new StringRefAddr("testOnBorrow", "true"));
    ref.add(new StringRefAddr("testOnReturn", "false"));
    ref.add(new StringRefAddr("testWhileIdle","true"));
    ref.add(new StringRefAddr("validationQuery","SELECT 1"));

    ref.add(new StringRefAddr("timeBetweenEvictionRunsMillis",Integer.toString(10*60*1000)));
    ref.add(new StringRefAddr("minEvictableIdleTimeMillis",Integer.toString(2*60*1000)));
    ref.add(new StringRefAddr("numTestsPerEvictionRun","10"));

    ref.add(new StringRefAddr("removeAbandoned", "true"));
    ref.add(new StringRefAddr("removeAbandonedTimeout", Integer.toString(30*60)));
    ref.add(new StringRefAddr("logAbandoned", "true"));

    Context ctx = new InitialContext();
    ctx.rebind("jdbc/MyDataSource",ref)
    ctx.close();

【讨论】:

    猜你喜欢
    • 2017-12-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-04-26
    相关资源
    最近更新 更多