proxool 配置详解


proxool 详细配置 proxool 一个数据库连接池框架,提供了对你选择的其它类型的驱动程序的连接池 封装。可以非常简单的移植到现存的代码中。完全可配置。快速,成熟,健壮。可以透明地 为你现存的 JDBC 驱动程序增加连接池功能。到目前为止最新版本是 proxool 0.9.1,可从官网 下载最新版本 http://proxool.sourceforge.net 一、配置 proxool.xml 文件 Xml 代码 dbname jdbc:oracle:thin:@127.0.0.1:1521:testdb oracle.jdbc.driver.OracleDriver 100 10 90000 10 5 true select sysdate from dual dbname jdbc:oracle:thin:@127.0.0.1:1521:testdb oracle.jdbc.driver.OracleDriver 100 10 90000 10 5 true select sysdate from dual 二、配置 web.xml Xml 代码 ServletConfigurator org.logicalcobwebs.proxool.configuration.ServletConfigurator xmlFile WEB-INF/proxool.xml 1 Admin org.logicalcobwebs.proxool.admin.servlet.AdminServlet Admin /admin proxool /admin manager BASIC proxool manager Application The role that is required to log in to the Manager Application manager 401 /401.jsp ServletConfigurator org.logicalcobwebs.proxool.configuration.ServletConfigurator xmlFile WEB-INF/proxool.xml 1 Admin org.logicalcobwebs.proxool.admin.servlet.AdminServlet Admin /admin proxool /admin manager BASIC proxool manager Application The role that is required to log in to the Manager Application manager 401 /401.jsp ServletConfigurator:加载并初始化 proxool.xml 文件,因为它是连接数据库的.其他很多模块都 用到数据,所以必须首先加载它 load-on-startup:数值越小,就会先被加载初始化 Admin:监控数据库连接池的连接情况 //获得数据库连接的语句 Connection conn=DriverManager.getConnection("proxool.dbname"); 注意:在 401.jsp 页面中必须加 <% response.setHeader("WWW-Authenticate", "Basic realm=\"Tomcat Manager Application\""); %>这句话,否则在访问/admin 察看连接池信息时,会直接跳转到 401.jsp 页面。我们是想让 访问 admin/的用户必须输入用户名和密码,且必须是 manager 角色,三次输入不正确才会 跳到 401.jsp 页面,如图 输入正确用户名和密码后才能看到 proxool 池的信息 三、更详细的 proxool.xml 的配置属性说明: Xml 代码 xml-test-ns jdbc:hsqldb:db/test org.hsqldb.jdbcDriver 40000 select CURRENT_DATE 10 3 18000000 5 40000 50000 60000 true true Fatal error 2 xml-test-ns-2 jdbc:hsqldb:db/test org.hsqldb.jdbcDriver 40000 select CURRENT_DATE 10 3 18000000 5 40000 50000 60000 true true Fatal error 2 xml-test-ns jdbc:hsqldb:db/test org.hsqldb.jdbcDriver 40000 select CURRENT_DATE 10 3 18000000 5 40000 50000 60000 true true Fatal error 2 xml-test-ns-2 jdbc:hsqldb:db/test org.hsqldb.jdbcDriver 40000 select CURRENT_DATE 10 3 18000000 5 40000 50000 60000 true true Fatal error 2 属性列表说明: fatal-sql-exception: 它是一个逗号分割的信息片段.当一个 SQL 异常发生时,他的异常信息将 与这个信息片段进行比较.如果在片段中存在,那么这个异常将被认为是个致命错误(Fatal SQL Exception ).这种情况下,数据库连接将要被放弃.无论发生什么,这个异常将会被重掷以提供给 消费者.用户最好自己配置一个不同的异常来抛出. fatal-sql-exception-wrapper-class:正如上面所说,你最好配置一个不同的异常来重掷.利用这个 属性,用户可以包装 SQLException,使他变成另外一个异常.这个异常或者继承 SQLException 或 者 继 承 字 RuntimeException.proxool 自带了 2 个实 现 :'org.logicalcobwebs.proxool.FatalSQLException' 和 'org.logicalcobwebs.proxool.FatalRuntimeException' .后者更合适. house-keeping-sleep-time: house keeper 保留线程处于睡眠状态的最长时间,house keeper 的 职责就是检查各个连接的状态,并判断是否需要销毁或者创建. house-keeping-test-sql: 如果发现了空闲的数据库连接.house keeper 将会用这个语句来测 试.这个语句最好非常快的被执行.如果没有定义,测试过程将会被忽略。 injectable-connection-interface: 允许 proxool 实现被代理的 connection 对象的方法. injectable-statement-interface: 允许 proxool 实现被代理的 Statement 对象方法. injectable-prepared-statement-interface: 允许 proxool 实现被代理的 PreparedStatement 对象 方法. injectable-callable-statement-interface: 允许 proxool 实现被代理的 CallableStatement 对象方 法. jmx: 略 jmx-agent-id: 略 jndi-name: 数据源的名称 maximum-active-time: 如果 housekeeper 检测到某个线程的活动时间大于这个数值.它将会 杀掉这个线程.所以确认一下你的服务器的带宽.然后定一个合适的值.默认是 5 分钟. maximum-connection-count: 最大的数据库连接数. maximum-connection-lifetime: 一个线程的最大寿命. minimum-connection-count: 最小的数据库连接数 overload-without-refusal-lifetime: 略 prototype-count: 连接池中可用的连接数量.如果当前的连接池中的连接少于这个数值.新的 连接将被建立(假设没有超过最大可用数).例如.我们有 3 个活动连接 2 个可用连接,而我们的 prototype-count 是 4, 那么数据库连接池将试图建立另外 2 个连接. 这和 minimum-connection-count 不同. minimum-connection-count 把 活 动 的 连 接 也 计 算 在 内.prototype-count 是 spare connections 的数量. recently-started-threshold: 略 simultaneous-build-throttle: 略 statistics: 连接池使用状况统计。 参数“10s,1m,1d” statistics-log-level: 日志统计跟踪类型。 参数“ERROR”或 “INFO” test-before-use: 略 test-after-use: 略 trace: 如果为 true,那么每个被执行的 SQL 语句将会在执行期被 log 记录(DEBUG LEVEL).你也 可以注册一个 ConnectionListener (参看 ProxoolFacade)得到这些信息. verbose: 详细信息设置。 参数 bool 值
还剩9页未读

继续阅读

下载pdf到电脑,查找使用更方便

pdf的实际排版效果,会与网站的显示效果略有不同!!

需要 8 金币 [ 分享pdf获得金币 ] 0 人已下载

下载pdf

pdf贡献者

yuxia82612

贡献于2012-08-20

下载需要 8 金币 [金币充值 ]
亲,您也可以通过 分享原创pdf 来获得金币奖励!
下载pdf