Java命名和目录接口(the Java naming and directory interface,JNDI)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得读者可以用名称访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性

tomcat配置jndi有全局配置和局部配置。大致的有以下三种配置方式:

1:局部配置。

步骤可以分3步

a.tomcat下的conf文件下server.xml文件中<host>添加如下代码

tomcat下jndi的三种配置方式_sql

 

代码如下:

<Context path="/jndi" docBase="/jndi">

  <Resource

name="jndi/test"

type="javax.sql.DataSource"

driverClassName="com.mysql.jdbc.Driver"

maxIdle="2"

maxWait="5000"

username="root"

password="abc123"

url="jdbc:mysql://localhost:3306/test"

maxActive="4"/>

</Context>

b.web.xml中需要配置的

tomcat下jndi的三种配置方式_xml_02

代码如下:

<resource-ref>

        <description>Test DataSource</description>

        <res-ref-name>jndi/test</res-ref-name>

        <res-type>javax.sql.DataSource</res-type>

        <res-auth>Container</res-auth>

    </resource-ref>

c.jndi测试方法

public void test() throws NamingException, SQLException{

Context ctx = new InitialContext();

DataSource ds = (DataSource) ctx.lookup("java:comp/env/jndi/test");

Connection conn = ds.getConnection();

System.out.println(conn.isClosed());

 

}

2:也是局部配置

在项目的META-INFO下面新建context.xml

tomcat下jndi的三种配置方式_视频教程_03

代码如下:

<?xml version="1.0" encoding="UTF-8"?>

<Context>

<Resource name="jndi/test" 

auth="Container" 

type="javax.sql.DataSource" 

driverClassName="com.mysql.jdbc.Driver" 

url="jdbc:mysql://localhost:3306/test" 

username="root" 

password="abc123" 

maxActive="20" 

maxIdle="10" 

maxWait="50000"/>

</Context>

3.全局配置

在tomcat的conf文件夹下的context.xml配置:

tomcat下jndi的三种配置方式_sql

代码如下:

<Context path="/jndi" docBase="/jndi">

  <Resource

name="jndi/test"

type="javax.sql.DataSource"

driverClassName="com.mysql.jdbc.Driver"

maxIdle="2"

maxWait="5000"

username="root"

password="abc123"

url="jdbc:mysql://localhost:3306/test"

maxActive="4"/>

</Context>

以上3种方式,分别是两种局部配置,一种全局配置,局部配置第一种分三步配置并且测试。这三种不同配置,只是jndi配置不同,其他b、c两步都是一样的。