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. python 列表解析与map和filter函数

    不知哪儿看到一个说法,大概是当map的函数参数可以直接引用一个已有的函数变量时(比如内建函数int,str之类的),用map更优美些,否则还是用列表解析更直观和快速. 我同意此说法. 昨天在写一个函数 ...

  2. RxJava操作符(04-过滤操作)

    转载请标明出处: http://blog.csdn.net/xmxkf/article/details/51656494 本文出自:[openXu的博客] 目录: Debounce Distinct ...

  3. ISP(Interface Segregation Principle),接口隔离原则

    ISP(Interface Segregation Principle),接口隔离原则 它要求如下: ①  一个类对另一个类的依赖性要建立在最小接口上. ②  使用多个专门的接口比使用单一的总接口要好 ...

  4. 【NPR】漫谈轮廓线的渲染

    写在前面 好久没写文章.最近在看<Real Time Rendering, third edition>这本书,看到了NPR这一章就想顺便记录下一些常见的轮廓线渲染的方法. 在非真实感渲染 ...

  5. [ExtJS5学习笔记]第二十节 Extjs5配合数组的push方法,动态创建并加载组件

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/39226773 官方例子:http://docs.sencha.com/extjs/5. ...

  6. Android初级教程初谈自定义view自定义属性

    有些时候,自己要在布局文件中重复书写大量的代码来定义一个布局.这是最基本的使用,当然要掌握:但是有些场景都去对应的布局里面写对应的属性,就显得很无力.会发现,系统自带的控件无法满足我们的要求,这个时候 ...

  7. ExtJS学习(二)Ext组件模型

    Ext中所有的组件都继承自Ext.component,这种单根继承的模型保证所有组件都拥有相同的通用方法与生命周期,这样在后续对这些组件进行维护管理时将更加便捷,同时也保证了在进行布局时的便利. 组件 ...

  8. python 访问 zookeeper

    python 访问 zookeeper zookeeper 分布式服务框架是 Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务.状态同 ...

  9. const引用

    在C++中可以声明const引用 const Type& name = var: const引用让变量拥有只读属性 const int &a = b const int &a ...

  10. Uva - 1593 - Alignment of Code

    直接用<iomanip>的格式输出,setw设置输出宽度,setiosflags(ios::left)进行左对齐. AC代码: #include <iostream> #inc ...