當前位置: 首頁>>代碼示例>>Java>>正文


Java GenericObjectPool類代碼示例

本文整理匯總了Java中org.apache.commons.pool.impl.GenericObjectPool的典型用法代碼示例。如果您正苦於以下問題:Java GenericObjectPool類的具體用法?Java GenericObjectPool怎麽用?Java GenericObjectPool使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


GenericObjectPool類屬於org.apache.commons.pool.impl包,在下文中一共展示了GenericObjectPool類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: DBManager

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
public DBManager() {
 ResourceBundle rb = PropertyResourceBundle.getBundle(
    "com.gint.app.bisisadmin.Config");
 String driver     = rb.getString("driver");
 String URL        = rb.getString("url");
 String username   = rb.getString("username");
 String password   = rb.getString("password");
	
 try {
   Class.forName(driver);
   GenericObjectPool connectionPool = new GenericObjectPool(null);
   DriverManagerConnectionFactory connectionFactory = 
     new DriverManagerConnectionFactory(URL, username, password);
   PoolableConnectionFactory poolableConnectionFactory =
     new PoolableConnectionFactory(connectionFactory, connectionPool, null, 
         null, false, false);
   poolingDataSource = new PoolingDataSource(connectionPool);
 } catch (Exception ex) {
   ex.printStackTrace();
 }  
}
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:22,代碼來源:DBManager.java

示例2: main

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
  Class.forName("com.mysql.jdbc.Driver");
  GenericObjectPool connectionPool = new GenericObjectPool(null);
  DriverManagerConnectionFactory connectionFactory = 
    new DriverManagerConnectionFactory("jdbc:mysql://localhost/bisis35?characterEncoding=UTF-8", 
        "bisis35", "bisis35");
  PoolableConnectionFactory poolableConnectionFactory =
    new PoolableConnectionFactory(connectionFactory, connectionPool, null, 
        null, false, true);
  PoolingDataSource poolingDataSource = new PoolingDataSource(connectionPool);
  
  RecordManagerImpl recMgr = new RecordManagerImpl();
  recMgr.setDataSource(poolingDataSource);
  
  Record rec1 = recMgr.getRecord(1);
  
  System.out.println(rec1);
}
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:19,代碼來源:RetrieverTest.java

示例3: ConnectionPooling

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * Constructor 
 *
 * Params:
 *
 *
 */
public ConnectionPooling(String connectionURL, String userName, String password, String driverName) throws ClassNotFoundException, SQLException{
	Class.forName(driverName);
	
	Properties props = new Properties();
	props.setProperty("user", userName);
	props.setProperty("password", password);
	
	ObjectPool connectionPool = new GenericObjectPool(null);
	
	ConnectionFactory connectionFactory = new DriverManagerConnectionFactory(connectionURL, props);
	
	PoolableConnectionFactory poolableConnectionFactory = new PoolableConnectionFactory(connectionFactory, 
			connectionPool, null, null, false, true);
	
	
	Class.forName("org.apache.commons.dbcp.PoolingDriver");
       PoolingDriver driver = (PoolingDriver) DriverManager.getDriver(myPoolingDriverName);
       driver.registerPool(myPoolName,connectionPool);
}
 
開發者ID:claresco,項目名稱:Tinman,代碼行數:27,代碼來源:ConnectionPooling.java

示例4: refreshChannelPool

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * Refresh the channel pool for the server.
 *
 * @param loc server address
 */
public void refreshChannelPool(Location loc) {
  try {
    lock.lock();
    GenericObjectPool<Channel> pool = locToChannelPoolMap.get(loc);
    if(pool == null) {
      return;
    } else {
      try {
        pool.close();
      } catch (Exception e) {
        LOG.error("Close channel for location " + loc +" error ", e);
      }
    }

    locToChannelPoolMap.put(loc, createPool(loc, pool.getNumActive() / 5));
  } finally {
    lock.unlock();
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:25,代碼來源:ChannelManager.java

示例5: removeChannelPool

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * Remove the channel pool for the server.
 *
 * @param loc server address
 */
public void removeChannelPool(Location loc) {
  try {
    lock.lock();
    GenericObjectPool<Channel> pool = locToChannelPoolMap.remove(loc);
    if (pool != null) {
      try {
        pool.close();
      } catch (Exception e) {
        e.printStackTrace();
      }
    }
  } finally {
    lock.unlock();
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:21,代碼來源:ChannelManager.java

示例6: clear

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * Clear and close all channels.
 */
public void clear() {
  try {
    lock.lock();
    for (Entry<Location, GenericObjectPool<Channel>> entry : locToChannelPoolMap.entrySet()) {
      try {
        entry.getValue().close();
      } catch (Exception e) {
        LOG.error("close channel pool failed, ", e);
      }
    }
    locToChannelPoolMap.clear();
  } finally {
    lock.unlock();
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:19,代碼來源:ChannelManager.java

示例7: createManagedDataSource

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
private DataSource createManagedDataSource(DataSource ds) {

        // wrap it with a LocalXAConnectionFactory
        XAConnectionFactory xaConnectionFactory = new LocalXAConnectionFactory(
                transactionManager, new DataSourceConnectionFactory(ds));

        GenericObjectPool pool = new GenericObjectPool();

        // create the pool object factory
        PoolableConnectionFactory factory = new PoolableConnectionFactory(
                xaConnectionFactory, pool, null, "SELECT DUMMY FROM DUAL",
                false, false);
        pool.setFactory(factory);

        ManagedDataSource managedDs = new ManagedDataSource(pool,
                xaConnectionFactory.getTransactionRegistry());
        managedDs.setAccessToUnderlyingConnectionAllowed(true);
        return managedDs;
    }
 
開發者ID:servicecatalog,項目名稱:oscm,代碼行數:20,代碼來源:TestPersistence.java

示例8: afterPropertiesSet

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
@Override
    public void afterPropertiesSet() throws Exception {
        ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
        // 加載Iface接口
        objectClass = classLoader.loadClass(serverAddressProvider.getService() + "$Iface");
        // 加載Client.Factory類
        Class<TServiceClientFactory<TServiceClient>> fi =
                (Class<TServiceClientFactory<TServiceClient>>) classLoader.
                        loadClass(serverAddressProvider.getService() + "$Client$Factory");
        TServiceClientFactory<TServiceClient> clientFactory = fi.newInstance();

        ThriftClientPoolFactory clientPool = new ThriftClientPoolFactory(serverAddressProvider,
                clientFactory, callback);
        pool = new GenericObjectPool<TServiceClient>(clientPool, makePoolConfig());

//        InvocationHandler handler = makeProxyHandler();//方式1
        InvocationHandler handler = makeProxyHandler2();//方式2
        proxyClient = Proxy.newProxyInstance(classLoader, new Class[] { objectClass }, handler);
    }
 
開發者ID:somewhereMrli,項目名稱:albedo-thrift,代碼行數:20,代碼來源:ThriftServiceClientProxyFactory.java

示例9: getObject

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
@Override
public T getObject() throws Exception {

    ClassLoader classLoader = Thread.currentThread().getContextClassLoader();

    Server server = serverManager.getService(innerClass.getName());

    // 加載Iface接口
    innerClass = classLoader.loadClass(server.getName());
    String temp = server.getName().replace("$Iface", "");
    // 加載Client.Factory類
    Class<TServiceClientFactory<TServiceClient>> fi =
            (Class<TServiceClientFactory<TServiceClient>>) classLoader.
                    loadClass(temp + "$Client$Factory");
    TServiceClientFactory<TServiceClient> clientFactory = fi.newInstance();

    ThriftClientPoolFactory clientPool =
            new ThriftClientPoolFactory(server,
                    clientFactory, callback, proccessName);
    pool = new GenericObjectPool<TServiceClient>(clientPool, makePoolConfig());

    ServiceProxy serviceProxy = new ServiceProxy(pool);

    return (T)Proxy.newProxyInstance(innerClass.getClassLoader(),new Class[]{innerClass}, serviceProxy);

}
 
開發者ID:somewhereMrli,項目名稱:albedo-thrift,代碼行數:27,代碼來源:ProxyFactoryBean.java

示例10: parserServers

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
protected void parserServers(@SuppressWarnings("rawtypes") List nodes)
		throws AlbianRemoteUNIDAttributeException {
	for (Object node : nodes) {
		IAlbianRemoteUNIDAttribute attr = parserServer((Element) node);
		if (null == attr)
			continue;
		_list.add(attr);
		GenericObjectPool.Config config = new GenericObjectPool.Config();
		config.maxActive = attr.getPoolSize();
		config.maxWait = 300;
		GenericObjectPool<Socket> pool = new GenericObjectPool<Socket>(
				new AlbianUNIDSocketConnectPoolFactory(attr),
				config) {
		};
		AlbianUNIDConnectPoolMap.insert(
				String.format("%s:%d", attr.getHost(), attr.getPort()),
				pool);
	}

}
 
開發者ID:crosg,項目名稱:Albianj2,代碼行數:21,代碼來源:AlbianRemoteUNIDService.java

示例11: doStart

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
@Override
protected void doStart() throws Exception {
    if (ObjectHelper.isEmpty(getNamedReplyTo())) {
        log.debug("No reply to destination is defined.  Using temporary destinations.");
    } else {
        log.debug("Using {} as the reply to destination.", getNamedReplyTo());
    }
    if (uuidGenerator == null) {
        // use the generator configured on the camel context
        uuidGenerator = getEndpoint().getCamelContext().getUuidGenerator();
    }
    if (consumers == null) {
        consumers = new GenericObjectPool<MessageConsumerResources>(new MessageConsumerResourcesFactory());
        consumers.setMaxActive(getConsumerCount());
        consumers.setMaxIdle(getConsumerCount());
        while (consumers.getNumIdle() < consumers.getMaxIdle()) {
            consumers.addObject();
        }
    }
    super.doStart();
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:22,代碼來源:InOutProducer.java

示例12: openConnectionAndChannelPool

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * Open connection and initialize channel pool
 * @throws Exception
 */
private synchronized void openConnectionAndChannelPool() throws Exception {
    log.trace("Creating connection...");
    this.conn = getEndpoint().connect(executorService);
    log.debug("Created connection: {}", conn);

    log.trace("Creating channel pool...");
    channelPool = new GenericObjectPool<Channel>(new PoolableChannelFactory(this.conn), getEndpoint().getChannelPoolMaxSize(),
            GenericObjectPool.WHEN_EXHAUSTED_BLOCK, getEndpoint().getChannelPoolMaxWait());
    if (getEndpoint().isDeclare()) {
        execute(new ChannelCallback<Void>() {
            @Override
            public Void doWithChannel(Channel channel) throws Exception {
                getEndpoint().declareExchangeAndQueue(channel);
                return null;
            }
        });
    }
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:23,代碼來源:RabbitMQProducer.java

示例13: getPoolConfig

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
/**
 * 獲取對象池配置
 * 
 * @return
 */
public GenericObjectPool.Config getPoolConfig() {
    GenericObjectPool.Config poolConfig = new GenericObjectPool.Config();
    // maxIdle為負數時,不對pool size大小做限製,此處做限製,防止保持過多空閑redis連接
    if (this.maxIdle >= 0) {
        poolConfig.maxIdle = this.maxIdle;
    }
    poolConfig.maxWait = this.maxWait;
    if (this.whenExhaustedAction >= 0 && this.whenExhaustedAction < 3) {
        poolConfig.whenExhaustedAction = this.whenExhaustedAction;
    }
    poolConfig.testOnBorrow = this.testOnBorrow;
    poolConfig.minIdle = this.minIdle;
    poolConfig.maxActive = this.maxActive;
    poolConfig.testOnReturn = this.testOnReturn;
    poolConfig.testWhileIdle = this.testWhileIdle;
    poolConfig.timeBetweenEvictionRunsMillis = this.timeBetweenEvictionRunsMillis;
    poolConfig.numTestsPerEvictionRun = this.numTestsPerEvictionRun;
    poolConfig.minEvictableIdleTimeMillis = this.minEvictableIdleTimeMillis;
    poolConfig.softMinEvictableIdleTimeMillis = this.softMinEvictableIdleTimeMillis;
    poolConfig.lifo = this.lifo;
    return poolConfig;
}
 
開發者ID:neoremind,項目名稱:navi-pbrpc,代碼行數:28,代碼來源:PooledConfiguration.java

示例14: configureGenericObjectPool

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
protected void configureGenericObjectPool(GenericObjectPool genericObjectPool) throws SyslogRuntimeException {
	SyslogPoolConfigIF poolConfig = null;
	
	try {
		poolConfig = (SyslogPoolConfigIF) this.syslog.getConfig();
		
	} catch (ClassCastException cce) {
		throw new SyslogRuntimeException("config must implement interface SyslogPoolConfigIF");
	}
	
	genericObjectPool.setMaxActive(poolConfig.getMaxActive());
	genericObjectPool.setMaxIdle(poolConfig.getMaxIdle());
	genericObjectPool.setMaxWait(poolConfig.getMaxWait());
	genericObjectPool.setMinEvictableIdleTimeMillis(poolConfig.getMinEvictableIdleTimeMillis());
	genericObjectPool.setMinIdle(poolConfig.getMinIdle());
	genericObjectPool.setNumTestsPerEvictionRun(poolConfig.getNumTestsPerEvictionRun());
	genericObjectPool.setSoftMinEvictableIdleTimeMillis(poolConfig.getSoftMinEvictableIdleTimeMillis());
	genericObjectPool.setTestOnBorrow(poolConfig.isTestOnBorrow());
	genericObjectPool.setTestOnReturn(poolConfig.isTestOnReturn());
	genericObjectPool.setTestWhileIdle(poolConfig.isTestWhileIdle());
	genericObjectPool.setTimeBetweenEvictionRunsMillis(poolConfig.getTimeBetweenEvictionRunsMillis());
	genericObjectPool.setWhenExhaustedAction(poolConfig.getWhenExhaustedAction());
}
 
開發者ID:syslog4j,項目名稱:syslog4j,代碼行數:24,代碼來源:GenericSyslogPoolFactory.java

示例15: setUp

import org.apache.commons.pool.impl.GenericObjectPool; //導入依賴的package包/類
protected void setUp() throws Exception {

        mockFactory = new Mock(PoolableObjectFactory.class);
        factory = (PoolableObjectFactory)mockFactory.proxy();
        
        pool = new GenericObjectPool(factory,
                1, // maxActive
                GenericObjectPool.WHEN_EXHAUSTED_BLOCK, // whenExhaustedAction
                60000, // maxWait (millis)
                1, // maxIdle
                true, // testOnBorrow
                false // testOnReturn
                );
        
        super.setUp();
    }
 
開發者ID:sakaiproject,項目名稱:sakai,代碼行數:17,代碼來源:GenericObjectPoolTest.java


注:本文中的org.apache.commons.pool.impl.GenericObjectPool類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。