Proxool线程池的简单实现demo

Proxool线程池的简单实现demo

使用的jar包:ojdbc14.jar    proxool-0.9.0.jar   commons-logging-1.1.3.jar

代码分为两部分: ProxoolTest.java和proxool.xml

第一部分代码:

ProxoolTest.java

package com.test.proxool;

import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;

import org.logicalcobwebs.proxool.configuration.JAXPConfigurator;

public class ProxoolTest {

int beginIndex = 0; // 待取记录起始数
int endIndex = 10; // 待取得记录终止跳
String MySQLdbTableName = “service”;
String MySQLreq = “select * from ” + MySQLdbTableName;

/**
* proxool方式测试
*
* @throws Exception
*/
public void proxoolMethodTest() throws Exception {
// Java应用中先要加载配置文件,否则谁知道你配置给谁用的
// JAXPConfigurator.configure(“proxool.xml”, false);
InputStream in = getClass().getResourceAsStream(‘/’+”proxool.xml”);
Reader reader = null;
reader = new InputStreamReader(in, “GBK”);
JAXPConfigurator.configure(reader, false);
// 1:注册驱动类,这次这个驱动已经不是Oracle的驱动了,是Proxool专用的驱动
Class.forName(“org.logicalcobwebs.proxool.ProxoolDriver”);
// 2:创建数据库连接,这个参数是一个字符串,是数据源的别名,在配置文件中配置的timalias,参数格式为:proxool.数据源的别名
Connection conn = DriverManager.getConnection(“proxool.timalias”);
for(int i = 0; i< 20; i++)
conn = DriverManager.getConnection(“proxool.timalias”);
// 3:创建执行SQL的对象
Statement stmt = conn.createStatement();
// 4:执行SQL,并获取返回结果
ResultSet res = stmt.executeQuery(MySQLreq);
// 5:处理返回结果,此处打印查询结果
ResultSetMetaData rsmd = res.getMetaData();
int columnCount = rsmd.getColumnCount();
int rowCount = 0;
while (res.next()) {
System.out.print(rowCount + ” “);
rowCount++;
for (int j = 1; j <= columnCount; j++) {// 循环处理
String strRes = res.getString(j);
System.out.print(strRes + “|\t”);
}
System.out.println();
}
// 6:关闭数据库连接
conn.close();
}

public static void main(String[] args) throws Exception {
ProxoolTest test = new ProxoolTest();
test.proxoolMethodTest();
}

}

  

第二部分代码:proxool.xml

<?xml version=”1.0″ encoding=”UTF-8″?>
<something-else-entirely>
<proxool>
<!–数据源的别名–>
<alias>oracle1</alias>
<!–url连接串–>
<driver-url>jdbc:oracle:thin:@198.131.89.16:1521:orclTest</driver-url>
<!–驱动类–>
<driver-class>oracle.jdbc.driver.OracleDriver</driver-class>
<driver-properties>
<!–用户名–>
<property name=”user” value=”gejinwen”/>
<!–密码–>
<property name=”password” value=”123456″/>
</driver-properties>
<!–最大连接数(默认5个),超过了这个连接数,再有请求时,就排在队列中等候,最大的等待请求数由maximum-new-connections决定 –>
<maximum-connection-count>5</maximum-connection-count>
<!–最小连接数(默认2个)–>
<minimum-connection-count>1</minimum-connection-count>
<!–proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁 默认30秒–>
<house-keeping-sleep-time>90000</house-keeping-sleep-time>
<!–没有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受–>
<maximum-new-connections>6</maximum-new-connections>
<!–最少保持的空闲连接数(默认2个)–>
<prototype-count>5</prototype-count>
<!–在使用之前测试–>
<test-before-use>true</test-before-use>
<!–用于保持连接的测试语句 –>
<house-keeping-test-sql>show tables</house-keeping-test-sql>
</proxool>
</something-else-entirely>

  注释已经很清楚了,没有什么多说的了。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109026.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • eric6教程(电脑的配置基本知识)

    欢迎加入QQ群:853840665,一块学习讨论单击菜单栏Setting-&gt;Preferences,进入设置界面 下面从上而下设置比较常用的设置,其他的各位可以自行研究1.设置编译器2.设置API3设置自动补全4.设置自动检查时间间隔默认是5S,我在用的时候发现经常代码该正确了,却还是提示错误,这里把时间改短5.设置字体大小…

    2022年4月15日
    41
  • Installous4 PC Client「建议收藏」

    Installous4 PC Client「建议收藏」Installous4PCClient下载程序请点这里写了一个IPhone上Installous4的PC端可以在电脑上搜索App以后再不用在手机上挂WIFI着下载了…哈哈哈相信越狱的同学

    2022年7月3日
    27
  • 简述TCP四次挥手

    简述TCP四次挥手四次握手主要用到了两个标志位(ACK&FIN):ACK示意参考:TCP三次握手FIN:终止数据传输标志位—->当FIN为1的时候代表此数据为终止断开连接的请求四次挥手流程:由于TCP连接是双向传输的对等的模式即双工wiki百科定义:全双工(full-duplex)的系统允许二台设备间同时进行双向资料传输。全双工的系统可以用复线铁路类比。两个方向的车辆因使用不同的轨道,因此不会互相影响。一般的电话、手机就是全双工的系统,因为在讲话时同时也可以听到对方的声音意思是说

    2022年5月29日
    55
  • 搭建J2ME开发平台

    搭建J2ME开发平台 1.导入设备定义你必须至少配置一种设备定义之后才能开始使用EclipseME。请按下列步骤来配置设备定义:从Eclipse的窗口菜单中选择首选项。打开左边面板的J2ME选项分支,点击设备管理(DeviceManagement)。 按导入…(Import)按钮。在接下来的对话框中,选择一个包含无线工具包的根目录,EclipseME将从中查找已知设备定

    2022年7月11日
    31
  • Vue路由懒加载_vuerouter路由懒加载

    Vue路由懒加载_vuerouter路由懒加载使用Vue路由懒加载时报了以下错误:经过百度发现,出现该问题的原因是:import属于异步引用组件,需要特殊的babel-loader处理解决办法:安装babel用来编译import异步引用方法的模块babel-plugin-syntax-dynamic-importcnpminstallbabel-plugin-syntax-dynamic-import-D在.b…

    2025年6月2日
    6
  • CSDN积分获取(csdn怎么查看积分)

    下载积分攻略:个人设置里进行手机绑定CSDN账户奖励50分(右上角设置-账户安全-手机绑定)完成任务送若干分积分http://task.csdn.net/上传有效资源获取积分(上传非法,广告资源用户,将被扣除一定积分,严重者封号)。·上传自己设分资源被下载,下载量×资源分,100分封顶。·上传0分资源被下载,下载量×系统奖励1分,100封顶评论资源获取积分(所下载资源只可以…

    2022年4月12日
    74

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号