All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.frameworkset.commons.dbcp2.NativeDataSource Maven / Gradle / Ivy

/*
 *  Copyright 2008 biaoping.yin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package com.frameworkset.commons.dbcp2;

import com.frameworkset.common.poolman.NestedSQLException;
import com.frameworkset.common.poolman.monitor.AbandonedTraceExt;
import com.frameworkset.commons.pool2.impl.AbandonedConfig;

import javax.sql.DataSource;
import java.io.PrintWriter;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
import java.util.logging.Logger;

/**
 * 
 * 

Title: NativeDataSource.java

* *

Description: 用户非连接池模式的数据源管理,当用户在连接池的配置文件指定 * usepool=false时,系统创建NativeDataSource类型的数据源 *

* *

Copyright: Copyright (c) 2007

* @Date 2011-3-4 下午02:06:01 * @author biaoping.yin * @version 1.0 */ public class NativeDataSource implements DataSource { private StaticCount staticCount; public static class StaticCount { private List traces = new ArrayList(); private boolean logAbandoned = false; public StaticCount(boolean logAbandoned) { this.logAbandoned = logAbandoned; } /** * 非链接池数据源活动链接数 */ private volatile int activeConnections = 0; /** * 非链接池数据源高峰链接数 */ private volatile int heapConnections = 0; private Object lock = new Object(); public void increments(AbandonedTraceExt connection) { synchronized(lock) { if(logAbandoned) addTraceObject(connection); activeConnections ++; if(heapConnections < activeConnections) heapConnections = activeConnections; } } public void decrements(AbandonedTraceExt trace) { synchronized(lock) { if(logAbandoned) removeTraceObject(trace); activeConnections --; } } protected int getActiveConnections() { return activeConnections; } protected int getHeapConnections() { return heapConnections; } private void addTraceObject(AbandonedTraceExt trace) { this.traces.add(trace); } private void removeTraceObject(AbandonedTraceExt trace) { this.traces.remove(trace); } public List getTraceObjects() { List dest = new ArrayList(); try { if(traces != null) dest.addAll(traces); } catch(Exception e) { } return dest; } } private String driver; private String url; private String user; private String password; private boolean defaultAutoCommit; private boolean defaultReadOnly; private int defaultTransactionIsolation; private String defaultCatalog; private DriverConnectionFactory driverConnectionFactory; protected AbandonedConfig abandonedConfig = null; /** * The connection properties that will be sent to our JDBC driver when * establishing new connections. NOTE - The "user" and * "password" properties will be passed explicitly, so they do not need to * be included here. */ protected Properties connectionProperties = new Properties(); private PrintWriter logWriter; public Connection getConnection() throws SQLException { this.createDataSource(); // Connection connection = this.driverConnectionFactory.createConnection(); StaticDelegateConnection connection = new StaticDelegateConnection(this.driverConnectionFactory.createConnection(),this.staticCount); return connection; } public Connection getConnection(String username, String password) throws SQLException { throw new UnsupportedOperationException("Not supported by BasicDataSource"); } public PrintWriter getLogWriter() throws SQLException { // TODO Auto-generated method stub return this.logWriter; } public int getLoginTimeout() throws SQLException { // TODO Auto-generated method stub return 0; } public void setLogWriter(PrintWriter out) throws SQLException { this.logWriter = out; } public void setLoginTimeout(int seconds) throws SQLException { } private void log(String message) { if (logWriter != null) { logWriter.println(message); } } private boolean created = false; protected DataSource createDataSource() throws SQLException { if (created) return this; synchronized (this) { if (created) return this; // Load the JDBC driver class if (driver != null) { try { Class.forName(driver); } catch (Throwable t) { String message = "Cannot load JDBC driver class '" + driver + "'"; if (logWriter != null) { logWriter.println(message); t.printStackTrace(logWriter); } throw new NestedSQLException(message, t); } } // Create a JDBC driver instance Driver driver = null; try { driver = DriverManager.getDriver(url); } catch (Throwable t) { String message = "Cannot create JDBC driver of class '" + (driver != null ? driver : "") + "' for connect URL '" + url + "'"; if (logWriter != null) { logWriter.println(message); t.printStackTrace(logWriter); } throw new NestedSQLException(message, t); } // Set up the driver connection factory we will use if (user != null) { connectionProperties.put("user", user); } else { log("DBCP DataSource configured without a 'username'"); } if (password != null) { connectionProperties.put("password", password); } else { log("DBCP DataSource configured without a 'password'"); } driverConnectionFactory = new DriverConnectionFactory(driver, url, connectionProperties); staticCount = new StaticCount(this.isLogAbandoned()); this.created = true; } return this; } /** * @return the driver */ public String getDriver() { return driver; } /** * @param driver * the driver to set */ public void setDriver(String driver) { this.driver = driver; } /** * @return the url */ public String getUrl() { return url; } /** * @param url * the url to set */ public void setUrl(String url) { this.url = url; } /** * @return the user */ public String getUser() { return user; } /** * @param user * the user to set */ public void setUser(String user) { this.user = user; } /** * @return the password */ public String getPassword() { return password; } /** * @param password * the password to set */ public void setPassword(String password) { this.password = password; } /** * @return the defaultAutoCommit */ public boolean isDefaultAutoCommit() { return defaultAutoCommit; } /** * @param defaultAutoCommit * the defaultAutoCommit to set */ public void setDefaultAutoCommit(boolean defaultAutoCommit) { this.defaultAutoCommit = defaultAutoCommit; } /** * @return the defaultReadOnly */ public boolean isDefaultReadOnly() { return defaultReadOnly; } /** * @param defaultReadOnly * the defaultReadOnly to set */ public void setDefaultReadOnly(boolean defaultReadOnly) { this.defaultReadOnly = defaultReadOnly; } /** * @return the defaultTransactionIsolation */ public int getDefaultTransactionIsolation() { return defaultTransactionIsolation; } /** * @param defaultTransactionIsolation * the defaultTransactionIsolation to set */ public void setDefaultTransactionIsolation(int defaultTransactionIsolation) { this.defaultTransactionIsolation = defaultTransactionIsolation; } /** * @return the defaultCatalog */ public String getDefaultCatalog() { return defaultCatalog; } /** * @param defaultCatalog * the defaultCatalog to set */ public void setDefaultCatalog(String defaultCatalog) { this.defaultCatalog = defaultCatalog; } /** * @return the logAbandoned */ public boolean isLogAbandoned() { if (abandonedConfig != null) { return abandonedConfig.getLogAbandoned(); } return false; } /** * @param logAbandoned the logAbandoned to set */ public void setLogAbandoned(boolean logAbandoned) { if (abandonedConfig == null) { abandonedConfig = new AbandonedConfig(); } if(logAbandoned) { abandonedConfig.setLogAbandoned(logAbandoned); } } public void addConnectionProperty(String propertyName, String propertyValue) { connectionProperties.put(propertyName, propertyValue); } public int getNumActive() { if(this.staticCount != null) { return this.staticCount.getActiveConnections(); } return 0; } public int getMaxNumActive() { if(this.staticCount != null) { return this.staticCount.getHeapConnections(); } return 0; } public List getTraces() { if(this.staticCount != null) { return this.staticCount.getTraceObjects(); } return new ArrayList(); } public Logger getParentLogger() throws SQLFeatureNotSupportedException { // TODO Auto-generated method stub return null; } @Override public T unwrap(Class iface) throws SQLException { // TODO Auto-generated method stub return null; } @Override public boolean isWrapperFor(Class iface) throws SQLException { // TODO Auto-generated method stub return false; } /** * added by biaoping.yin 20150115 * @return */ public List getGoodTraceObjects() { return this.staticCount.getTraceObjects(); } public synchronized void close() throws SQLException { } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy