1. configuration MySql Connection DataSource

原理介绍

java 调用 Tomcat 中的 ConnectionPool 通过Context 中去查找  jndi 的方式

那么目标就明确了 Java ==jndi==> Tomcat ===> Databases

1) 因为是连接池所以需要 $CATALINA_HOME/lib/tomcat-dbcp.jar 包

     把这个jar 包放到对就的Tomcat 目录下当然一般Tomcat 目录下有。

2) 要连接数据库 所以要jdbc 驱动 $CATALINA_HOME/lib/ mysql-connector-java-5.1.6-bin.jar

注意:tomcat 4.x 放在 $CATALINA_HOME/ common/lib目录下

   将这个jar 包放到Tomcat 目录下同上 OK 在以上物理条件都存在的条

件了。。

 

 3) 配置逻辑条件 $CATALINA_HOME/conf/ context.xml 配置

  1. <Context>
  2. <!-- Default set of monitored resources -->
  3. <WatchedResource>WEB-INF/web.xml</WatchedResource>
  4. <!-- Uncomment this to disable session persistence across Tomcat restarts -->
  5. <!--
  6. <Manager pathname="" />
  7. -->
  8. <!-- Uncomment this to enable Comet connection tacking (provides events
  9. on session expiration as well as webapp lifecycle) -->
  10. <!--
  11. <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" />
  12. -->
  13. <Resource name="jdbc/mysqlDB" auth="Container" type="javax.sql.DataSource"
  14. maxActive="100" maxIdle="30" maxWait="10000"
  15. username="root" password="123456" driverClassName="com.mysql.jdbc.Driver"
  16. url="jdbc:mysql://localhost:3306/test?autoReconnect=true"/>
  17. </Context>

 4) 服务端配置好后 我们就来配置 工程下的web.xml 文件中来告诉Tomcat 容器 我要什么连接。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  3. <display-name>webJNdi</display-name>
  4. <description>MySQL Test App</description>
  5. <!-- 告诉 Tomcat Container 我要jdbc/mysqlDb 数据源 -->
  6. <resource-ref>
  7. <description>DB Connection</description>
  8. <res-ref-name>jdbc/mysqlDB</res-ref-name>
  9. <res-type>javax.sql.DataSource</res-type>
  10. <res-auth>Container</res-auth>
  11. </resource-ref>
  12. <welcome-file-list>
  13. <welcome-file>index.html</welcome-file>
  14. <welcome-file>index.htm</welcome-file>
  15. <welcome-file>index.jsp</welcome-file>
  16. <welcome-file>default.html</welcome-file>
  17. <welcome-file>default.htm</welcome-file>
  18. <welcome-file>default.jsp</welcome-file>
  19. </welcome-file-list>
  20. </web-app>

5)测试页面

方式一:

  1. <%@page import="javax.naming.InitialContext"%>
  2. <%@page import="javax.naming.Context"%>
  3. <%@ page language="java" contentType="text/html; charset=UTF-8"
  4. pageEncoding="UTF-8"%>
  5. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  6. <html>
  7. <head>
  8. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  9. <title>测试Tomcat Container</title>
  10. </head>
  11. <body>
  12. <%
  13. Context ctx = new InitialContext();
  14. Context env = (Context)ctx.lookup("java:/comp/env");
  15. Object ob = env.lookup("jdbc/mysqlDB");
  16. %>
  17. <h1>Tomcat Container Connection MySqlObjectName:<%=ob %>
  18. </body>
  19. </html>

方式二:

  1. <%@page import="javax.naming.InitialContext"%>
  2. <%@page import="javax.naming.Context"%>
  3. <%@page import="java.sql.*"%>
  4. <%@page import="javax.sql.*"%>
  5. <%@ page language="java" contentType="text/html; charset=UTF-8"
  6. pageEncoding="UTF-8"%>
  7. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  8. <html>
  9. <head>
  10. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  11. <title>测试Tomcat Container</title>
  12. </head>
  13. <body>
  14. <%
  15. Context ctx = new InitialContext();
  16. DataSource ds = (DataSource)ctx.lookup( "java:/comp/env/jdbc/mysqlDB" );
  17. %>
  18. <h1>Tomcat Container Connection MySqlObjectName:<%=ds %>
  19. </body>
  20. </html>

Tomcat 4.x 的配置方法

   与上面版本不同配置在server.xml 中添加内容 

  1. <Resource name="jdbc/MysqlDB"
  2. auth="Container"
  3. type="javax.sql.DataSource"/>
  4. <ResourceParams name="jdbc/MysqlDB">
  5. <parameter>
  6. <name>factory</name>
  7. <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
  8. </parameter>
  9. <!-- Maximum number of dB connections in pool. Make sure you
  10. configure your mysqld max_connections large enough to handle
  11. all of your db connections. Set to 0 for no limit.
  12. -->
  13. <parameter>
  14. <name>maxActive</name>
  15. <value>100</value>
  16. </parameter>
  17. <!-- Maximum number of idle dB connections to retain in pool.
  18. Set to 0 for no limit.
  19. -->
  20. <parameter>
  21. <name>maxIdle</name>
  22. <value>30</value>
  23. </parameter>
  24. <!-- Maximum time to wait for a dB connection to become available
  25. in ms, in this example 10 seconds. An Exception is thrown if
  26. this timeout is exceeded.  Set to -1 to wait indefinitely.
  27. -->
  28. <parameter>
  29. <name>maxWait</name>
  30. <value>10000</value>
  31. </parameter>
  32. <!-- MySQL dB username and password for dB connections  -->
  33. <parameter>
  34. <name>username</name>
  35. <value>root</value>
  36. </parameter>
  37. <parameter>
  38. <name>password</name>
  39. <value>123456</value>
  40. </parameter>
  41. <!-- Class name for mm.mysql JDBC driver -->
  42. <parameter>
  43. <name>driverClassName</name>
  44. <value>org.gjt.mm.mysql.Driver</value>
  45. </parameter>
  46. <!-- The JDBC connection url for connecting to your MySQL dB.
  47. The autoReconnect=true argument to the url makes sure that the
  48. mm.mysql JDBC Driver will automatically reconnect if mysqld closed the
  49. connection.  mysqld by default closes idle connections after 8 hours.
  50. -->
  51. <parameter>
  52. <name>url</name>
  53. <value>jdbc:mysql://localhost:3306/test?autoReconnect=true</value>
  54. </parameter>
  55. </ResourceParams>

同样在web.xml 中指定这里不变

运行结果

  1. Tomcat Container Connection
  2. MySqlObjectName:org.apache.tomcat.dbcp.dbcp.BasicDataSource@17f409c

Tomcat configuration DataSource的更多相关文章

  1. Tomcat Server Configuration Automation Reinforcement

    目录 . 引言 . 黑客针对WEB Server会有那些攻击面 . 针对Tomcat Server可以做的安全加固 . Managing Security Realms with JMX . 实现对T ...

  2. Tomcat数据源(DataSource)简介

    JDBC2.0提供了javax.sql.DataSource接口,它负责建立与数据库的连接,在应用程序中访问数据库时不必编写连接数据库的代码,可以直接从数据源获得数据库连接 1.数据库和连接池 在Da ...

  3. Spring Boot JDBC:加载DataSource过程的源码分析及yml中DataSource的配置

    装载至:https://www.cnblogs.com/storml/p/8611388.html Spring Boot实现了自动加载DataSource及相关配置.当然,使用时加上@EnableA ...

  4. tomcat 部署指南

    下载与安装 个人建议不要使用发行版带的版本, 始终从主页来下载安装, 下载地址位于[1], 安装方法很简单, 直接解压即可, 建议解压到 /usr/local/ 目录, 再链接到 /usr/local ...

  5. CentOS RHEL 安装 Tomcat 7

    http://www.davidghedini.com/pg/entry/install_tomcat_7_on_centos This post will cover installing and ...

  6. Tomcat应用中post方式传参数长度限制

    Tomcat应用中post方式传参数长度限制 jsp页面上是没有限制的,但是在tomcat服务器上有限制,Tomcat 默认的post参数的最大大小为2M, 当超过时将会出错,可以配置maxPostS ...

  7. Redirect HTTP to HTTPS on Tomcat

    I have bought my SSL secure certificate and successfully installed on Tomcat with the keytool but ho ...

  8. Idea 使用maven+tomcat的时候,编译指定的Profile

    To build a artifact with a profile you have to create a Maven Run/Debug configuration as in the foll ...

  9. Tomcat 7.0配置SSL的问题及解决办法

    http://dong-shuai22-126-com.iteye.com/blog/1830209   以前一直在用Tomcat 6.0.29版本,今下载了apache-tomcat-7.0.33- ...

随机推荐

  1. Android艺术开发探索第三章————View的事件体系(下)

    Android艺术开发探索第三章----View的事件体系(下) 在这里就能学习到很多,主要还是对View的事件分发做一个体系的了解 一.View的事件分发 上篇大致的说了一下View的基础知识和滑动 ...

  2. Excel 数据验证宏

    Sub 宏1() ' ' 宏1 宏 ' ' With Selection.Validation .Delete .Add Type:=xlValidateList, AlertStyle:=xlVal ...

  3. 供应商导入的API补充(详解EBS接口开发之供应商导入)

    --供应商 --创建 AP_VENDOR_PUB_PKG.Create_Vendor ( p_api_version IN NUMBER, p_init_msg_list IN VARCHAR2 := ...

  4. ORACLE数据库学习之备份与恢复

     oracle数据库的备份与恢复 第一部分:数据库的备份 备份的必要性 因为各种人为或外界的因素可能会造成数据库中灾难性的数据丢失,为了保证数据库中数据的安全,必须采取备份措施保证RDBMS中包含 ...

  5. 剑指offer面试题3 二维数组中的查找(c)

    剑指offer面试题三:

  6. H3C数据中心虚拟化解决方案技术白皮书

    缩略语清单: 缩略语 英文全名 中文解释 IDC Internet Data Center 互联网数据中心 VRF Virtual Router Forwarding 虚拟路由器转发 SMP Symm ...

  7. Struts2处理流程性需求的一种解决方案

    在应用程序设计中,经常出现如下的需求. 查看用户填写的数据,而且数据是分页填写. 看下面这个情况 用户的信息有三页,分别是Form abc. 现在的问题是,后面的逻辑该如何设计. 如果把,FormAB ...

  8. Java Math的 floor,round和ceil

    floor 返回不大于的最大整数 round 则是4舍5入的计算,入的时候是到大于它的整数 round方法,它表示"四舍五入",算法为Math.floor(x+0.5),即将原来的 ...

  9. MySQL聚簇索引的使用介绍

    MySQL聚簇索引保证关键字的值相近的元组存储的物理位置也相同(所以字符串类型不宜建立聚簇索引,特别是随机字符串,会使得系统进行大量的移动操作),且一个表只能有一个聚簇索引.因为由存储引擎实现索引,所 ...

  10. C语言--指针函数和函数指针

    指针函数和函数指针 指针函数其实是一个简称,是指带指针的函数,它本质上是一个函数,只是返回的是某种类型的指针.其定义的格式为: 类型标识符 *函数名(参数表)  函数指针,从本质上说是一个指针,只是它 ...