JNDI配置c3p0连接池
2015-08-06 21:52
232 查看
JNDI是什么呢?
就是java命名和目录接口,是SUN公司提供的一种标准的Java命名系统接口。
不好理解?简单说呢,他就是一个资源,放在tomcat里面的一个资源,今天我们就把数据库连接池放到tomcat中,当然你也可以放别的东西,比如Been。
ok!开始
首先我们新建web项目:
命名就是:项目名.xml
在我这就叫:JNDI_demo.xml
在这简单说下这个配置文件:
然后我们导入jar包(c3p0jar+mysql驱动jar):点击下载jar包
好了没有了,对了我把web.xml也放上吧,不过这个是自己生成的,我没改。
然后我们启动tomcat,然后访问:http://localhost:8080/JNDI_demo/servlet/JNDI_Servlet
回车看见的空白,就说明成功了。我们看控制台打印的信息:
说明了我们已经成功获取了c3p0的数据库连接。这个打印的是改对象!,如果没有成功,可以给我留言。一起分享,一起学习。
就是java命名和目录接口,是SUN公司提供的一种标准的Java命名系统接口。
不好理解?简单说呢,他就是一个资源,放在tomcat里面的一个资源,今天我们就把数据库连接池放到tomcat中,当然你也可以放别的东西,比如Been。
ok!开始
首先我们新建web项目:
新建项目叫:JNDI_demo然后在tomcat目录:F:\apache-tomcat-5.5.25\conf\Catalina\localhost下,创建一个资源。
命名就是:项目名.xml
在我这就叫:JNDI_demo.xml
<Context> <Resource name="datasource/c3p0DataSource" type="com.mchange.v2.c3p0.ComboPooledDataSource" factory="org.apache.naming.factory.BeanFactory" driverClass="com.mysql.jdbc.Driver" jdbcUrl="jdbc:mysql://localhost:3306/test" user="root" password="root" acquireIncrement="3" initialPoolSize="5" maxPoolSize="10" minPoolSize="2" /> </Context>
在这简单说下这个配置文件:
name="随意起,待会项目中要用" type=你创建资源的类型,这里我们要创建的是c3p0连接池,对应的类全名就是:com.mchange.v2.c3p0.ComboPooledDataSource factory不可以改动
下面就是连接池的配置信息,注意小写字母开头,你们把账号密码改成自己的,再创建一个数据库叫test的。
好了。接下来我们就创建一个servlet,来获取这个连接池资源获取数据库连接。
我们新建一个Servlet: JNDI_Servlet
package com; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; public class JNDI_Servlet extends HttpServlet { /** * 我们获取tomcat中配置的c3p0的实践课连接池资源。 */ private static final long serialVersionUID = 1L; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取tomcat配置数据库连接池 try { Context cxt = new InitialContext(); //lookup里面必须以java:comp/env/开头+你刚写的配置文件的name的值 DataSource ds = (DataSource)cxt.lookup("java:comp/env/datasource/c3p0DataSource"); Connection con = ds.getConnection(); System.out.println("con:"+con); } catch (Exception e) { // TODO Auto-generated catch block throw new RuntimeException(); } } }
然后我们导入jar包(c3p0jar+mysql驱动jar):点击下载jar包
好了没有了,对了我把web.xml也放上吧,不过这个是自己生成的,我没改。
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <display-name></display-name> <servlet> <description>This is the description of my J2EE component</description> <display-name>This is the display name of my J2EE component</display-name> <servlet-name>JNDI_Servlet</servlet-name> <servlet-class>com.JNDI_Servlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>JNDI_Servlet</servlet-name> <url-pattern>/servlet/JNDI_Servlet</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
然后我们启动tomcat,然后访问:http://localhost:8080/JNDI_demo/servlet/JNDI_Servlet
回车看见的空白,就说明成功了。我们看控制台打印的信息:
con:com.mchange.v2.c3p0.impl.NewProxyConnection@1b1bbe8
说明了我们已经成功获取了c3p0的数据库连接。这个打印的是改对象!,如果没有成功,可以给我留言。一起分享,一起学习。
相关文章推荐
- MySQL中的数据类型
- 第二章 图形界面还是命令窗口
- Sublime配置python开发环境
- Qt的学习记录卡
- 【瞎搞】 HDU 5358 First One
- 【android】利用getViewTreeObserver().addOnGlobalLayoutListener()获得一个视图的高度
- HDOJ题目4417 Super Mario(划分树求区间比k小的个数+二分)
- 范师兄的面经
- 函数实现不放在头文件的原因,及何时可以放头文件的情况
- mysql 使用
- iOS设计模式之命令模式
- [科研小记]
- JS和C语言判断闰年
- PPT投影仪演示设置
- iOS 透明视图控制器
- Android之Notification的推荐用法
- 第一章 关于linux的历史
- Effective STL(2)
- Scala模式匹配下提取器构造
- mysql 高可用5