📄 xapoolconnectionfactory.java
字号:
/* * $Id: XaPoolConnectionFactory.java 6609 2006-01-29 09:50:01Z jonesde $ * * Copyright (c) 2003 The Open For Business Project - www.ofbiz.org * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT * OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */package org.ofbiz.entity.transaction;import java.sql.Connection;import java.sql.SQLException;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set;import org.enhydra.jdbc.pool.StandardXAPoolDataSource;import org.enhydra.jdbc.standard.StandardXADataSource;import org.ofbiz.base.util.Debug;import org.ofbiz.base.util.ObjectType;import org.ofbiz.entity.GenericEntityException;import org.w3c.dom.Element;/** * JotmFactory - Central source for JOTM JDBC Objects * * @author <a href="mailto:jaz@ofbiz.org">Andy Zeneski</a> * @version $Rev: 6609 $ * @since 2.1 */public class XaPoolConnectionFactory { public static final String module = XaPoolConnectionFactory.class.getName(); protected static Map dsCache = new HashMap(); public static Connection getConnection(String helperName, Element jotmJdbcElement) throws SQLException, GenericEntityException { StandardXAPoolDataSource pds = (StandardXAPoolDataSource) dsCache.get(helperName); if (pds != null) { if (Debug.verboseOn()) Debug.logVerbose(helperName + " pool size: " + pds.pool.getCount(), module); return TransactionFactory.getCursorConnection(helperName, pds.getConnection()); } synchronized (XaPoolConnectionFactory.class) { pds = (StandardXAPoolDataSource) dsCache.get(helperName); if (pds != null) { return pds.getConnection(); } // the xapool wrapper class String wrapperClass = jotmJdbcElement.getAttribute("pool-xa-wrapper-class"); StandardXADataSource ds = null; try { //ds = new StandardXADataSource(); ds = (StandardXADataSource) ObjectType.getInstance(wrapperClass); pds = new StandardXAPoolDataSource(); } catch (NoClassDefFoundError e) { throw new GenericEntityException("Cannot find xapool.jar"); } catch (ClassNotFoundException e) { throw new GenericEntityException("Cannot load wrapper class: " + wrapperClass, e); } catch (InstantiationException e) { throw new GenericEntityException("Unable to instantiate " + wrapperClass, e); } catch (IllegalAccessException e) { throw new GenericEntityException("Problems getting instance of " + wrapperClass, e); } if (ds == null) throw new GenericEntityException("StandardXaDataSource was not created, big problem!"); ds.setDriverName(jotmJdbcElement.getAttribute("jdbc-driver")); ds.setUrl(jotmJdbcElement.getAttribute("jdbc-uri")); ds.setUser(jotmJdbcElement.getAttribute("jdbc-username")); ds.setPassword(jotmJdbcElement.getAttribute("jdbc-password")); ds.setDescription(helperName); ds.setTransactionManager(TransactionFactory.getTransactionManager()); String transIso = jotmJdbcElement.getAttribute("isolation-level"); if (transIso != null && transIso.length() > 0) { if ("Serializable".equals(transIso)) { ((StandardXADataSource) ds).setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE); } else if ("RepeatableRead".equals(transIso)) { ((StandardXADataSource) ds).setTransactionIsolation(Connection.TRANSACTION_REPEATABLE_READ); } else if ("ReadUncommitted".equals(transIso)) { ((StandardXADataSource) ds).setTransactionIsolation(Connection.TRANSACTION_READ_UNCOMMITTED); } else if ("ReadCommitted".equals(transIso)) { ((StandardXADataSource) ds).setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED); } else if ("None".equals(transIso)) { ((StandardXADataSource) ds).setTransactionIsolation(Connection.TRANSACTION_NONE); } } // set the datasource in the pool pds.setDataSource(ds); pds.setDescription(ds.getDescription()); pds.setUser(ds.getUser()); pds.setPassword(ds.getPassword()); Debug.logInfo("XADataSource: " + ds.getClass().getName() + " attached to pool.", module); // set the transaction manager in the pool pds.setTransactionManager(TransactionFactory.getTransactionManager()); // configure the pool settings try { pds.setMaxSize(new Integer(jotmJdbcElement.getAttribute("pool-maxsize")).intValue()); pds.setMinSize(new Integer(jotmJdbcElement.getAttribute("pool-minsize")).intValue()); pds.setSleepTime(new Long(jotmJdbcElement.getAttribute("pool-sleeptime")).longValue()); pds.setLifeTime(new Long(jotmJdbcElement.getAttribute("pool-lifetime")).longValue()); pds.setDeadLockMaxWait(new Long(jotmJdbcElement.getAttribute("pool-deadlock-maxwait")).longValue()); pds.setDeadLockRetryWait(new Long(jotmJdbcElement.getAttribute("pool-deadlock-retrywait")).longValue()); // set the test statement to test connections String testStmt = jotmJdbcElement.getAttribute("pool-jdbc-test-stmt"); if (testStmt != null && testStmt.length() > 0) { pds.setJdbcTestStmt(testStmt); Debug.logInfo("Set JDBC Test Statement : " + testStmt, module); } } catch (NumberFormatException nfe) { Debug.logError(nfe, "Problems with pool settings; the values MUST be numbers, using defaults.", module); } catch (Exception e) { Debug.logError(e, "Problems with pool settings", module); } // cache the pool dsCache.put(helperName, pds); return TransactionFactory.getCursorConnection(helperName, pds.getConnection()); } } public static void closeAll() { Set cacheKeys = dsCache.keySet(); Iterator i = cacheKeys.iterator(); while (i.hasNext()) { String helperName = (String) i.next(); StandardXAPoolDataSource pds = (StandardXAPoolDataSource) dsCache.remove(helperName); pds.shutdown(true); } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -