proxool的使用总结

在项目中使用proxool做数据源管理,这里记录下配置代码与需要注意的事项。

添加jar包:proxool-0.9.0RC3.jar 在WEB-INF下,创建proxool.xml文件,代码如下:

 

数据源名
        jdbc:mysql://localhost:3306/数据库名
	com.mysql.jdbc.Driver
        
        
        
        
        
        

        40000
        250
        3
        3000000 
        5
        400000
        500000
        600000
        true
        true
        select CURRENT_DATE
        Fatal error
        2
	INFO

 

:proxool.xml的配置参数详细说明请参考这里

然后在web.xml文件中进行配置,添加如下代码:

 

ServletConfigurator
	org.logicalcobwebs.proxool.configuration.ServletConfigurator
	
		xmlFile
		WEB-INF/proxool.xml
	
	1


	Admin
	org.logicalcobwebs.proxool.admin.servlet.AdminServlet
-->

 

上述代码中被注释掉的部分在开发过程中可以释放,如果释放,则会开启数据源监控页面,如果您的访问地址为www.xxx.com,那么数据源监控URL为:www.xxx.com/admin。网站发布到服务器上后,建议关闭该功能。

 

注意:如果工程中存在监听器,而监听器中调用了数据库中的数据,那么在系统启动的时候会报错

java.sql.SQLException: org.logicalcobwebs.proxool.ProxoolException: Attempt to refer to a unregistered pool by its alias ‘别名’

或者

java.sql.SQLException: No suitable driver found for '数据源名'

 这时的解决方案为:把proxool交给监听器进行处理:

新建类:

 

import java.io.File;
import java.util.Enumeration;
import java.util.Properties;

import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.logicalcobwebs.proxool.ProxoolException;
import org.logicalcobwebs.proxool.configuration.JAXPConfigurator;
import org.logicalcobwebs.proxool.configuration.PropertyConfigurator;

/**
 * @author wangtao
 */

public class ProxoolListener implements ServletContextListener {
	private static final Log LOG = LogFactory.getLog(ProxoolListener.class);

	private static final String XML_FILE_PROPERTY = "xmlFile";

	private static final String PROPERTY_FILE_PROPERTY = "propertyFile";

	private static final String AUTO_SHUTDOWN_PROPERTY = "autoShutdown";

	@SuppressWarnings("unused")
	private boolean autoShutdown = true;

	public void contextDestroyed(ServletContextEvent arg0) {
		System.out.println("destroy database pool....");
	}

	@SuppressWarnings("unchecked")
	public void contextInitialized(ServletContextEvent contextEvent) {
		System.out.println("init................");
		ServletContext context = contextEvent.getServletContext(); // 对应servlet的init方法中ServletConfig.getServletContext()
		String appDir = contextEvent.getServletContext().getRealPath("/");
		Properties properties = new Properties();

		Enumeration names = context.getInitParameterNames();
		while (names.hasMoreElements()) {
			String name = (String) names.nextElement();
			String value = context.getInitParameter(name);

			if (name.equals(XML_FILE_PROPERTY)) {
				try {
					File file = new File(value);
					if (file.isAbsolute()) {
						JAXPConfigurator.configure(value, false);
					} else {
						JAXPConfigurator.configure(appDir + File.separator + value, false);
					}
				} catch (ProxoolException e) {
					LOG.error("Problem configuring " + value, e);
				}
			} else if (name.equals(PROPERTY_FILE_PROPERTY)) {
				try {
					File file = new File(value);
					if (file.isAbsolute()) {
						PropertyConfigurator.configure(value);
					} else {
						PropertyConfigurator.configure(appDir + File.separator + value);
					}
				} catch (ProxoolException e) {
					LOG.error("Problem configuring " + value, e);
				}
			} else if (name.equals(AUTO_SHUTDOWN_PROPERTY)) {
				autoShutdown = Boolean.valueOf(value).booleanValue();
			} else if (name.startsWith("jdbc")) { // 此处以前是PropertyConfigurator.PREFIX改为jdbc,因为此源码是0.9.1版本的,与0.9RC3版本有点不一样
				properties.setProperty(name, value);
			}
		}

		if (properties.size() > 0) {
			try {
				PropertyConfigurator.configure(properties);
			} catch (ProxoolException e) {
				LOG.error("Problem configuring using init properties", e);
			}
		}
	}

}

 

然后web.xml中的配置如下:

 

xmlFile
	WEB-INF/proxool.xml

 

 

获取数据源连接代码:

 

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DBConnectionManager {
	private static Connection conn;
	public static Connection getConnection()
	  {
		try
	    {
	      conn = DriverManager.getConnection("proxool.数据源名");
	      if (conn == null)
	      {
	        throw new SQLException("数据库无值");
	      }

	    }
	    catch (Exception ex)
	    {
	      System.out.println(ex.getMessage());
	      ex.printStackTrace();
	    }

	    return conn;
	  }
}

 

参考资料:http://cbf0713.blog.163.com/blog/static/907789052010510105453412/

              http://sunnylocus.javaeye.com/blog/359570

作者: saeba 发表于 2010-11-12 16:52 原文链接

评论: 0 查看评论 发表评论

最新新闻:
· Apache 上托管的项目将迁移到 Google Code(2010-12-15 08:24)
· 传诺基亚将在芬兰裁员800人(2010-12-15 08:22)
· 我为什么喜欢独自编程(2010-12-15 07:38)
· 雅虎宣布裁员4%约600人 遣散费为两个月工资(2010-12-15 07:37)
· 微软拟对Office 2007推新功能 增强安全性(2010-12-15 07:36)

编辑推荐:WP7有约(二):课后作业

网站导航:博客园首页  我的园子  新闻  闪存  小组  博问  知识库

转载于:https://my.oschina.net/woqi/blog/11135

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值