- 浏览: 666158 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (297)
- J2SE (78)
- swt/飞信 (20)
- mysql/mssql (17)
- 设计模式 (5)
- windows (18)
- 闲言碎语 (19)
- struts 1.x (6)
- JVM (6)
- tomcat/jetty (8)
- jquery/javascript (15)
- web前端 (6)
- J2EE (0)
- PHP (6)
- 算法设计 (17)
- 数据结构 (3)
- C/C++ (6)
- linux (19)
- 程序打包 (8)
- eclipse/myeclipse (10)
- 其他杂项 (13)
- 应聘 (9)
- spring/spring mvc (4)
- Maven/Ant (2)
- ERROR (1)
- nosql/hbase (1)
- hibernate (3)
- Solr/Lucene (1)
最新评论
-
乔木1937:
太感谢了,看到你的文章终于解决这个问题了!
[转载]通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。错误:“Connection refused: connect。 -
xianweisi:
竟然还有马
精简JRE - 实例Swing计算器 with 精简JRE(续) -
Javkburd:
我刚也遇到这个问题,然后也把默认端口改成了1433,只差最后没 ...
[转载]通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。错误:“Connection refused: connect。 -
yeshaoting:
kingbinchow 写道 最近的爪哇岛 没有什么货进项呀 ...
jQuery方法区别(四)click() bind() live() delegate()区别 -
kingbinchow:
最近的爪哇岛 没有什么货进项呀!
jQuery方法区别(四)click() bind() live() delegate()区别
6. JNDI方式 - 配置Tomcat6.0 连接池
数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量,使用情况,为系统开发,测试及性能调整提供依据。
数据库连接池技术带来的优势:
a) 资源重用
由于数据库连接得到重用,避免了频繁创建、释放连接引起的大量性能开销。在减少系统消耗的基础上,另一方面也增进了系统运行环境的平稳性(减少内存碎片以及数据库临时进程/线程的数量)。
b) 更快的系统响应速度
数据库连接池在初始化过程中,往往已经创建了若干数据库连接置于池中备用。此时连接的初始化工作均已完成。对于业务请求处理而言,直接利用现有可用连接,避免了数据库连接初始化和释放过程的时间开销,从而缩减了系统整体响应时间。
c) 新的资源分配手段
对于多应用共享同一数据库的系统而言,可在应用层通过数据库连接的配置,实现数据库连接池技术,几年前也许还是个新鲜话题,对于目前的业务系统而言,如果设计中还没有考虑到连接池的应用,那么…….快在设计文档中加上这部分的内容吧。某一应用最大可用数据库连接数的限制,避免某一应用独占所有数据库资源。
d) 统一的连接管理,避免数据库连接泄漏
在较为完备的数据库连接池实现中,可根据预先的连接占用超时设定,强制收回被占用连接。从而避免了常规数据库连接操作中可能出现的资源泄漏。
一般步骤:
6.1 配置JNDI Resource
自tomcat 5.5起数据库连接池的配置和以前的不同了,不推荐在server.xml中进行配置,
而是在%Tomcat_Home%\webapps\yourApp\META-INF\context.xml中进行配置才是更好的方法。
而不是以前版本%Tomcat_Home%\conf\context.xml文件。这样就可以在不同的web应用下单独配置连接池了,且Tomcat会自动重载。当然你也可以更改%Tomcat_Home%\conf下的context.xml文件,将所有web应用下的连接池进行统一配置。
因为server.xml是不可动态重加载的资源,服务器一旦启动了以后,要修改这个文件,就得重启服务器才能重新加载。而context.xml文件则不然,tomcat服务器会定时去扫描这个文件。一旦发现文件被修改(时间戳改变了),就会自动重新加载这个文件,而不需要重启服务器。
注:这一步容易报错:Cannot create JDBC driver of class '' for connect URL 'null'
context.xml内容:
<!-- The contents of this file will be loaded for each web application -->
<Context>
<Resource name="jdbc/db" auth="Container"
type="javax.sql.DataSource"
maxActive="30" maxIdle="10" maxWait="10000"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/mydb"
username="root" password="root" />
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<WatchedResource>WEB-INF/struts-config.xml</WatchedResource>
</Context>
相关说明:
name 为当前数据源JNDI的名字,可以随意设定;
auth 为验证方式;
type 资源类型;
maxActiv 为连接池最大激活的连接数,设为0表示无限制;
maxIdle 为连接池最大空闲的连接数,数据库连接的最大空闲时间。超过空闲时间,
数据库连接将被标记为不可用,然后被释放。设为0表示无限制;
maxWait 为连接最大的等待时间,单位毫秒,如果超过此时间将接到异常。设为-1表示无限制。;
driverClassName 为驱动引用;
url 为连接数据库的连接地址;
username 为数据库的一个用户名;
password 为username的密码;
<WatchedResource>标签内定义服务器在运行期监视的资源文件.服务器根据前后(修改)时间戳来判断是否发生修改,如若发生修改则重新加载该文件.
6.2 配置web.xml
关于这一步,貌似不是必须的,好像可以省略.
web.xml内容:
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/db</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
注意: <res-ref-name>填写的内容要与在上文提到的JNDI Name名称一致,即与context.xml中<Resource>标签的name属性值相同。虽然<res-type>标签内容虽然在<Resource>标签内容相同,但是是必不可少的.<res-auth>标签貌似可以省略,默认就是权限就是Container.
6.3 连接数据库进行登录验证
一般步骤:
a) 获取当前服务器加载的context内容.Context context = new InitialContext();
这里是第1步中提到的context内容.
加载优先顺序是:conf/server.xml中<Resource>标签内容 -> conf/context.xml中<Resource>标签内容 -> conf/Catalina/主机名(e.g. localhost)/项目名.xml
注: conf/Catalina/主机名(e.g. localhost)/项目名.xml是Tomcat布署时,由项目目录/WebRoot/META-INF/context.xml生成(Tomcat启动进行布署后,conf/Catalina/主机名(e.g. localhost)/项目名.xml与WebRoot/META-INF/context.xml内容一样,名字由context.xml变成项目名.xml).
b) 导入两个类包commons-dbcp和commons-pool(来自apache)
javax.sql.DataSource是一个接口,Tomcat采用commons-dbcp包中类org.apache.commons.dbcp.BasicDataBase作为其的实现类,或者说是实例创建类,还是关联在一起??(不了解过程,说不好).
Context ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/db");
或者
Context ctx = new InitialContext();
Context envCtx = (Context) ctx.lookup("java:comp/env");
DataSource ds = (DataSource) envCtx.lookup("jdbc/db");
关键代码:
private static Connection conn;
private static PreparedStatement stmt;
if (conn == null || conn.isClosed())
{
String name = "java:comp/env/jdbc/db";
Context context = new InitialContext();
DataSource data = (DataSource) context.lookup(name);
conn = data.getConnection();
stmt = conn.prepareStatement(sql);
}
发表评论
-
Java - Convert String to enum
2012-11-17 22:03 1853http://stackoverflow.com/que ... -
[ERROR]Premature end of file
2012-09-28 11:41 3210[ERROR]Premature end of file ... -
测试java.util.Map.Entry
2012-07-18 16:13 971/** * Copyright (c) 201 ... -
关于eclipse启动出错问题的解决办法
2012-06-09 09:31 1392转自:http://blog.csdn.net/jkpt ... -
Myeclipse中把java代码导成UML类图
2012-05-18 14:53 2307MyEclipse 中选择window,在 Open ... -
[转载]java synchronized详解
2012-05-15 17:18 808http://www.cnblogs.com ... -
[转载]Java 根据 HashMap 的 value 进行排序
2012-05-08 09:58 897转载:http://www.oschina.net/co ... -
JAVA实时屏幕监控
2012-04-29 16:13 3243JAVA实时屏幕监控 说明: 本程序会运 ... -
[JAVA实时屏幕监控]JAVA使用Internet代理设置
2012-04-29 14:50 1323JAVA使用Internet代理设置 描述:首先 ... -
[JAVA实时屏幕监控]JAVA通过注册表获取Internet代理设置
2012-04-29 14:47 2282JAVA通过注册表获取Internet代理设置 ... -
[JAVA实时屏幕监控]JAVA发送邮件
2012-04-29 14:28 2425JAVA发送邮件 描述:利用commons-em ... -
[JAVA实时屏幕监控]JAVA屏幕截图
2012-04-29 14:19 1256JAVA屏幕截图 /** * 产生截图 ... -
[JAVA实时屏幕监控]Java使用代理服务器
2012-04-24 13:36 2399/** * Copyright (c) 2012 T ... -
java.util.ConcurrentModificationException解决办法
2012-04-23 10:47 1519java.util.ConcurrentModi ... -
[转载]java.util.ConcurrentModificationException
2012-04-23 09:20 918java.util.ConcurrentModif ... -
整数转换成字节型数组
2012-04-22 13:16 5958整数转换成字节型数组 描述: 整数(in ... -
java.lang.NoClassDefFoundError: javax/mail/Message解决方法
2012-04-18 10:33 1197缺少activation.jar 和 mail.jar ... -
设置javax.swing.JFrame窗口外观
2012-03-29 15:34 0设置javax.swing.JFrame窗口外 ... -
设置javax.swing.JFrame窗口外观
2012-03-29 15:34 0设置javax.swing.JFrame窗口 ... -
Java图形界面外观包substance.jar
2012-03-29 15:33 0一直以来都认为用Swing做出来的程序 ...
相关推荐
自用CVE-2018-3191 weblogic反序列化exp。
eclipse与glassfish3.1.1使用配置-连接池配置-JNDI配置[归纳].pdf
tomcat6.0JNDI连接数据库 中配置代码
Tomcat5配置MysqlJDBC数据库连接池(JNDI方式)
NULL 博文链接:https://zzy603.iteye.com/blog/1039826
tomcat-jndi
javaJNDI连接数据库
NULL 博文链接:https://shijian4810.iteye.com/blog/1165175
自己总结的三种使用方式,对比来看选择最适合你的方式
基于weblogic,应对数据库连接泄漏的解决方法; 包含临时解决方法和数据连接池泄露监控,并可追踪到某个类某行代码。
JAVA数据库连接池(C3P0,Druid,JNDI ,DBCP,Proxool,BoneCP) 源码包含各个数据库连接池的连接DEMO spring+mybatis+maven
经过实践归纳的,参考了tomcat6.0关于配置JNDI的官方文档。经过测试可以配置成功和使用。
tomcat6.0中配置JNDI的DBCP连接
简单我tomcat5.0中的JNDI应用
tomcat-jndi-数据源将 tomcat-maven-plugin 与 JNDI 数据源一起使用
$ java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar [-C] [command] [-A] [address] where: -C - command executed in the remote classfile. (optional , default command is "open /Applications/...
java asm jndi_JNDI-Injection-Exploit,用于log4j2漏洞验证 可执行程序为jar包,在命令行中运行以下命令: $ java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar [-C] [command] [-A] [address] 其中: -C ...
tomcat配置jndi、数据库连接jndi、jndi实例、非常简单,可以快速学习入门。有连接数据库的例子,和具体的配置。
1、java数据库操作基本流程2、几个常用的重要技巧:·可滚动、更新的记录集·批量更新·事务处理java数据库操作基本流程:取得数据库连接-执行sql语句-处理执行结果-释放数据库连接l、取得数据库连接1)用DriverManager...
c3p0配置数据库连接池、数据库连接池 已经测试通过,可以提供给新入门的朋友学习之用,如果是要结合spring就不用下载了,网上其他地方应该很多资料,简单修改一下,原理都是一样的。