eclipse tomcat JNdi配置笔记
来源:互联网 发布:php实现跨域 编辑:程序博客网 时间:2024/06/05 00:40
一、遇到的错误
1.Name 项目名 is not bound in this Context
2.Name jdbc is not bound in this Context
解决方法:<res-ref-name> 这里写成 jdbc/项目名 </res-ref-name>
3.Cannot create JDBC driver of class '' for connect URL 'null'class '' for connect URL 'null
检查配置:(1)web.xml (2)tomcat/conf/server.xml
二、具体配置
1.web.xml
<resource-ref><span style="white-space:pre"></span><description>DB Connection</description> <res-ref-name>DingdanManager</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth></resource-ref>
2.server.xml
<Context docBase="DingdanManager" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:DingdanManager" ><Resource auth="Container" name="jdbc/DingdanManager" type="javax.sql.DataSource"/><ResourceParams name="jdbc/DingdanManager"><parameter><name>factory</name><value>org.apache.commons.dbcp.BasicDataSourceFactory</value></parameter><parameter><name>maxActive</name><value>10</value></parameter><parameter><name>maxIdle</name><value>10</value></parameter><parameter><name>maxWait</name><value>10000</value></parameter><parameter><name>driverClassName</name><value>com.mysql.jdbc.Driver</value></parameter><parameter><name>url</name><value>jdbc:mysql://localhost/test</value></parameter><parameter><name>validationQuery</name><value>select 1 from dual</value></parameter><parameter><name>testWhileIdle</name><value>true</value></parameter><parameter><name>username</name><value>root</value></parameter><parameter><name>password</name><value>pwd</value></parameter></ResourceParams></Context>
需要注意的是:Context起初是<Context docBase="study" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:study"/>这样的,最后有个/> ,我们写Resource的时候就要去掉/ ,然后在最后补上 </Context>
3.tomcat的lib下要放相应数据库链接的jar包,比如:mysql---mysql-connector-java.jar Oracle--ojdbc14.jar
4.如果是tomcat5.0 以上的工作就结束了。如果是6.0、7.0,还需要在web项目下的META-INF下放置content.xml
<?xml version="1.0" encoding="UTF-8"?><Context><Resource name="jdbc/DingdanManager" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost/test" username="root" password="root" maxActive="100" maxIdle="10" maxWait="10000"/></Context>
三、各参数ss含义
name 表示指定的jndi名称
auth 表示认证方式,一般为Container
type 表示数据源床型,使用标准的javax.sql.DataSource
maxActive 表示连接池当中最大的数据库连接
maxIdle 表示最大的空闲连接数
maxWait 当池的数据库连接已经被占用的时候,最大等待时间
logAbandoned 表示被丢弃的数据库连接是否做记录,以便跟踪
username 表示数据库用户名
password 表示数据库用户的密码
driverClassName 表示JDBC DRIVER
url 表示数据库URL地址
四、使用
import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import javax.naming.Context;import javax.naming.InitialContext;import javax.naming.NamingException;import javax.sql.DataSource;public class Jndi {public synchronized static Connection createConn(){Connection conn = null;try{//初始化查找命名空间 Context ctx = new InitialContext(); //InitialContext ctx = new InitialContext();亦可 //找到DataSource,对名称进行定位java:comp/env是必须加的,后面跟你的DataSource名 DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/DingdanManager");conn = ds.getConnection();} catch (NamingException e) { System.out.println(e.getMessage());} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}return conn;}}
- eclipse tomcat JNdi配置笔记
- Eclipse +Tomcat配置JNDI数据源
- Eclipse +Tomcat配置JNDI数据源
- Tomcat hibernate JNDI 配置
- Tomcat JNDI配置
- tomcat 配置JNDI
- tomcat JNDI数据源配置
- tomcat jndi配置
- tomcat 配置jndi datasource
- Tomcat JNDI配置
- tomcat JNDI 配置
- Tomcat 6 配置 JNDI
- Tomcat 配置JNDI 数据源
- tomcat配置JNDI步骤
- tomcat JNDI数据源配置
- Tomcat JNDI配置
- tomcat dbcp jndi 配置
- tomcat 下jndi配置
- LeetCode Sudoku Solver 回溯
- input core输入事件 矩阵键盘 映射 原理分析
- 大端小端
- highcharts如何动态获取数据
- mvc4 部署到win service 2008 r2 报错403
- eclipse tomcat JNdi配置笔记
- 10003---Tomcat建立虚拟主机最佳实践
- mysql必知必会(一)
- 60安全浏览器可以通过指定内核的方式来解决兼容性问题。
- 如何使用IntelliJ IDEA搭建spark开发环境(上)
- 【探秘ES6】系列专栏
- vim配置及插件安装管理(超级详细)
- iOS在线音频播放FreeStreamer
- API之SOA和数据格式