Java tutorial
/* * Copyright 2002-2014 the original author or authors. * * 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.dempe.lamp.client; import io.netty.channel.Channel; import io.netty.channel.ChannelFuture; import org.apache.commons.pool2.BasePooledObjectFactory; import org.apache.commons.pool2.PooledObject; import org.apache.commons.pool2.impl.DefaultPooledObject; import java.util.logging.Level; import java.util.logging.Logger; /** * Pool Object Factory for netty channel * * @author sunzhongyi, xuyuepeng * @author xiemalin */ public class ChannelPoolObjectFactory extends BasePooledObjectFactory<Connection> { private static final Logger LOGGER = Logger.getLogger(ChannelPoolObjectFactory.class.getName()); private CommonClient rpcClient; public ChannelPoolObjectFactory(CommonClient rpcClient) { this.rpcClient = rpcClient; } /* * (non-Javadoc) * * @see org.apache.commons.pool2.BasePooledObjectFactory#create() */ @Override public Connection create() throws Exception { return fetchConnection(); } /* * (non-Javadoc) * * @see org.apache.commons.pool2.BasePooledObjectFactory#wrap(java.lang.Object) */ @Override public PooledObject<Connection> wrap(Connection obj) { Connection connection = fetchConnection(); ChannelFuture future = this.rpcClient.connect(); // Wait until the connection is made successfully. future.awaitUninterruptibly(); if (!future.isSuccess()) { LOGGER.log(Level.SEVERE, "failed to get result from stp", future.cause()); } else { connection.setIsConnected(true); } connection.setFuture(future); return new DefaultPooledObject<Connection>(connection); } public Connection fetchConnection() { return new Connection(); } public void destroyObject(PooledObject<Connection> p) throws Exception { Connection c = p.getObject(); Channel channel = c.getFuture().channel(); if (channel.isOpen() && channel.isActive()) { channel.close(); } } public boolean validateObject(PooledObject<Connection> p) { Connection c = p.getObject(); Channel channel = c.getFuture().channel(); return channel.isOpen() && channel.isActive(); } /** * activateObject will invoke every time before it borrow from the pool * * @param p target pool object * @throws Exception */ public void activateObject(PooledObject<Connection> p) throws Exception { } }