Java的连接池技术
来源:互联网 发布:尼特族 知乎 编辑:程序博客网 时间:2024/05/20 16:33
如何使用JNDI(Java Naming and Directory Interface)是一个应用程序接口,为开发人员提供了查找和访问各种命名和目录服务的通用,统一的接口,类似JDBC都是构建在抽象层上。JNDI提供了一种统一的方式,可以用在网络上查找和访问服务。通过指定一个资源名称,该名称对应于数据库或命名服务中的一个一个记录,同时返回数据库连接建立所必需的信息。
在实际开发中,我们有时候还会使用服务器提供给我们的数据库连接池,比如我们希望Tomcat服务器在启动的时候可以帮助我们创建一个数据库连接池,那么我们在应用程序中就不需要手动去创建数据库连接池,直接使用Tomcat服务器创建好的数据库连接池即可。要想让Tomcat服务器再启动的时候帮我们创建一个数据库连接池‘,那么需要简单配置一下Tomcat服务器。
配置过程如下:
(1)将数据库驱动程序(jar包)放到Tomcat安装目录下的lib文件夹中。
(2)在项目的WebContent\META-INF\目录下手动创建一个context.xml文件,编辑里面的内容,最终内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="525825GAOzhe"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://localhost:1433;DatabaseName=test" />
</Context>
(3)再在上面WebContent\META-INF\目录下手动创建一个web.xml文件,编辑里面的内容,最终内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/test</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</web-app>
(3)创建一个jsp页面,进行数据库的访问测试,代码如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.sql.*, javax.sql.*,javax.naming.*,com.microsoft.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>数据库连接测试</title>
</head>
<body>
<%
Connection con=null;
try{
Context ctx=new InitialContext();
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/test");
con=ds.getConnection();
System.out.println("connection pool connectioned!!");
con.close();
}catch(NamingException e){
System.out.println(e.getMessage());
}catch(SQLException e){
e.printStackTrace();
}finally{
con.close();
}
%>
</body>
</html>
到此为止,数据库的连接池就已经创建好了。
- Java的连接池技术
- java连接池技术
- 用java的nio技术实现的异步连接池
- 主流的Java连接池技术及性能比较
- 连接池技术的实用
- Java技术回顾之JDBC:连接池
- jdbc pool java连接池技术
- jdbc pool java连接池技术
- Java技术回顾之JDBC:连接池
- 实现连接池技术的例子
- 谈谈Jedis的连接池技术
- 用java反射技术创建通用的JDBC连接
- 面向连接的技术
- 使用JAVA技术连接SAP
- 技术-Java连接mysql数据库
- JAVA:连接池技术说明以及MVC设计模式理解
- Java中使用连接池技术链接数据库
- 连接池技术
- Oracle 11g 密码过期问题
- 一般线程与独立线程
- C语言之类型转换
- CSS一列布局
- 绘制饼状图(自定义控件)
- Java的连接池技术
- HTTP POST GET 本质区别详解
- 各种语言中字符串转换为数字 数字转换为字符串
- 当JDK的安装目录包含空格时,如何在命令行编译代码
- Ubuntu Linux 下 Ffmpeg 及 Mencoder 安装使用小结
- android:visibility="gone"
- iOS插件化研究之一——JavaScriptCore
- C++多线程编程
- [www.infoshare.cc]解决5037端口被占据问题