tomcat下jndi的三种配置方式
往期精选
● 架构师高并发高性能分布式教程(4000G)
● 互联网技术干货****大全【菜单为准】
● 2017年8月最新Intellij IDEA全套****
更多精彩查看历史记录和公众号菜单.........
Java命名和目录接口(the Java naming and directory interface,JNDI)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得读者可以用名称访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性
tomcat配置jndi有全局配置和局部配置。大致的有以下三种配置方式:
1:局部配置。
步骤可以分3步
a.tomcat下的conf文件下server.xml文件中<host>添加如下代码
代码如下:
<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中需要配置的
代码如下:
<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
代码如下:
<?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配置:
代码如下:
<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两步都是一样的。