配置Tomcat数据源

虽然在生产环境中很少用到Tomcat的数据源,但考虑到知识的完整性,觉得还是得学习一下这部分东西,以下是我的学习总结:

1.局部连接池配置方法

1.1.准备工作:

新建一个web工程,导入mysql数据库jar包

1.2.配置步骤:

1.2.1.在项目中的META-INF目录下新增一个context.xml文件,context.xml文件内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<Context>
 <Resource name="jdbc/DBpool" auth="Container" type="javax.sql.DataSource"
  username="root" password="123456" maxIdle="10" maxActive="100"
  maxWait="1000" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/test" />
</Context>

注释:Resource 标签:定义数据源

        name:数据源名称

        auth:由容器创建和管理

        type:数据源类型

        username:数据库用户名

        password:数据库用户密码

        maxIdle:最大数据库空闲连接数量

        maxActive:最大数据库活跃连接数量

        maxWait:最大数据库等待连接数量

        driverClassName:数据库连接驱动

        url:连接数据库的连接地址

1.2.2.新建DBPool.java

package dbpool;
import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
public class DBPool {
 private Connection conn;
 public Connection createConn() throws NamingException, SQLException {
  Context initCtx = new InitialContext();
  // Context envCtx = (Context) initCtx.lookup("java:comp/env")
  // DataSource ds = (DataSource) envCtx.lookup("jdbc/DbPool");
  DataSource ds = (DataSource) initCtx
    .lookup("java:comp/env/jdbc/DBpool");
  conn = ds.getConnection();
  System.out.println("数据库连接成功!");
  return conn;
 }
}

1.2.3.创建一个测试页面,访问DBPool类中的createConn方法

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@page import="dbpool.DBPool"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
  <title>DBPoolTest</title>
 </head>
 <body>
<%
  DBPool dbPool=new DBPool();
 %>
 <%=dbPool.createConn()%>
 </body>
</html>

1.2.4.启动tomcat,运行项目,直接访问DBPoolTest.jsp,此时页面会出现

jdbc:mysql://localhost:3306/test, UserName=root@localhost , MySQL-AB JDBC Driver信息,后台控制台中也会打出“数据库连接成功!”的提示信息。

2.全局数据源配置方法

2.1).全局数据源配置方法一

2.1.1).在tomcat目录conf/server.xml中的配置如下:

<GlobalNamingResources> 
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  <!--新增dataSource-->
  <Resource name="jdbc/dataSourceDemo" auth="Container" type="javax.sql.DataSource"
  driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/test"
  username="root" password="123456" maxActive="50" maxIdle="20" maxWait="1000" />
  </GlobalNamingResources>

2.1.2).在tomcat目录conf/context.xml中的配置如下:

<Context>
   <ResourceLink name="jdbc/dataSourceDemo" global="jdbc/dataSourceDemo" type="javax.sql.DataSource"/>
    <WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>

2.1.3).编写数据源查找类:

package test;
import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
public class DBHelper {
  public static Connection getConnection() throws NamingException, SQLException{
   Context initContext=new InitialContext();
   Context envContext=(Context) initContext.lookup("java:/comp/env");
   DataSource ds=(DataSource)envContext.lookup("jdbc/dataSourceDemo");
   return ds.getConnection();
  }
}

2.1.4).编写数据源调用页面

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%@page import="test.DBHelper" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>dataSource</title>
  </head>
  <body>
    <%
    DBHelper dbHelper=new DBHelper();
    System.out.println(dbHelper.getConnection());
     %>
  </body>
</html>

2.2).全局数据源配置方法二 

2.2.1).直接在conf/context.xml中配置,而无需在server.xml中配置,其他配置一样,现配置如下:

<Context>
   <Resource name="jdbc/dataSourceDemo" auth="Container" type="javax.sql.DataSource"
  driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/mysql"
  username="root" password="123456" maxActive="50" maxIdle="20" maxWait="1000" />
    <WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>

3.结束语

在写这篇博文的之前,我查了一些资料,阅读了一下其他优秀的博文,在实际实验的时候,发现如下几点疑惑:

  1. 配置局部数据源时,如果第一次成功,再去改动数据源名称时数据源便报错,而配置全局数据源时,便不会出错,查找相关资料也没有找到解决方案。

  2. 无论是在配置局部数据源还是全局数据源,都无需在web.xml中配置如下代码:

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

你可能感兴趣的:(配置Tomcat数据源)