设为首页 收藏本站
查看: 425|回复: 0

[经验分享] [转]Tomcat配置JNDI数据源

[复制链接]

尚未签到

发表于 2017-1-29 10:33:38 | 显示全部楼层 |阅读模式
[标题]:[转]Tomcat配置JNDI数据源
[时间]:2009-6-12
[摘要]:在Tomcat中配置JNDI数据源
[关键字]:MySQL,JDBC,Driver,Tomcat,JNDI,DataSource
[环境]:Tomcat6,mysql-connector-java-5.1.7-bin.jar
[作者]:Winty (wintys@gmail.com) http://www.blogjava.net/wintys

[正文]:
1、将MySQL JDBC驱动(mysql-connector-java-5.1.7-bin.jar)放到%TOMCAT_HOME%"lib目录下。注意,不要放到webapps/myjdbc的WEB-INF目录中,否则可能出现"SQL Exception:Cannot load JDBC driver class 'com.mysql.jdbc.Driver' "。

2、在Tomcat的webapps目录创建一个工程目录,例如myjdbc。在myjdbc目录下创建META-INF目录,在此目录下创建一个context.xml文件,里面的内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<Context>
    <Resource name="jdbc/mysql_ds_db"
            auth="Container"
            type="javax.sql.DataSource"
            maxActive="100"
            maxIdle="30"
            maxWait="10000"
            username="root"
            password="root"
            driverClassName="com.mysql.jdbc.Driver"
            url="jdbc:mysql://localhost:3306/db"/>
</Context>


Tomcat标准数据源资源工厂配置项如下:
* driverClassName - 所使用的JDBC驱动类全称。
* maxActive - 同一时刻可以自数据库连接池中被分配的最大活动实例数。
* maxIdle - 同一时刻数据库连接池中处于非活动状态的最大连接数。
* maxWait - 当连接池中没有可用连接时,连接池在抛出异常前将等待的最大时间,单位毫秒。
* password - 传给JDBC驱动的数据库密码。
* url - 传给JDBC驱动的连接URL。
* user - 传给JDBC驱动的数据库用户名。
* validationQuery - 一个SQL查询语句,用于在连接被返回给应用前的连接池验证。
如果指定了该属性,则必为至少返回一行记录的SQL SELECT语句。

3、在myjdbc目录下创建WEB-INF目录,创建web.xml文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
    xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

<resource-ref>
    <description>DB Connection</description>
    <res-ref-name>jdbc/mysql_ds_db</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>

</web-app>


说明:
    <resource-ref>
    <descrtiption>引用资源说明</descrtiption>
    <res-ref-name>引用资源的JNDI名</res-ref-name>
    <res-type>引用资源的类名</res-type>
    <res-auth>管理者(Container)</res-auth><!--Container-容器管理 Application-Web应用管理-->
    </resource-ref>

4、测试
JSP测试:
<%@page contentType="text/html;charset=GBK" %>
<%@ page import="java.sql.*,javax.sql.*,javax.naming.*" %>
2009-6-9
测试Tomcat JNDI 数据源:<br/>
<%
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/mysql_ds_db");
   //取出连接
   conn = ds.getConnection();
    out.println("connection pool connected !!");
  } catch (NamingException e) {
    out.println("Naming Exception:" + e.getMessage());
  } catch (SQLException e) {
   out.println("SQL Exception:" + e.getMessage());
  }finally{
   if(conn != null)
       conn.close();//注意不是关闭,是放回连接池.
  }
%>


或写个JSP用标签库测试一下:
<%@page contentType="text/html;charset=GBK" %>
<%@taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<sql:setDataSource
    dataSource="jdbc/mysql_ds_db"
    var="ds" />

<sql:query var="query" dataSource="${ds}" >
    select * from bookauthor
</sql:query>

<c:forEach var="row" items="${query.rows}">
    authorId:<c:out value="${row.authorId}" /><br/>
    authorName:<c:out value="${row.authorName}" /> <br/>
    <br/>
</c:forEach>



[参考资料]:
[1] Tomcat配置JNDI数据源: http://www.blogjava.net/supercrsky/archive/2009/05/01/174931.html
[2] Tomcat 6.0 设置 JNDI 数据源 : http://www.blogjava.net/Michael-Q/archive/2008/03/26/188867.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-334825-1-1.html 上篇帖子: Tomcat连接池配置,如此简易 下篇帖子: 不用重启Tomcat自动的更新
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表