⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 xapoolconnectionfactory.java

📁 Sequoia ERP是一个真正的企业级开源ERP解决方案。它提供的模块包括:电子商务应用(e-commerce), POS系统(point of sales),知识管理,存货与仓库管理
💻 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 + -