You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
32 lines
1008 B
32 lines
1008 B
package core.thrift;
|
|
|
|
import org.apache.commons.pool2.BasePooledObjectFactory;
|
|
import org.apache.commons.pool2.PooledObject;
|
|
import org.apache.commons.pool2.impl.DefaultPooledObject;
|
|
import org.apache.thrift.transport.TNonblockingSocket;
|
|
import org.apache.thrift.transport.TTransport;
|
|
|
|
|
|
public class ConnectionPoolFactory extends BasePooledObjectFactory<TTransport>{
|
|
private String ip;
|
|
private int port;
|
|
private int socketTimeout;
|
|
|
|
public ConnectionPoolFactory(String ip,int port,int socketTimeout) {
|
|
this.ip = ip;
|
|
this.port = port;
|
|
this.socketTimeout = socketTimeout;
|
|
}
|
|
|
|
@Override
|
|
//创建TTransport类型对象方法
|
|
public TTransport create() throws Exception {
|
|
return new TNonblockingSocket(ip, port,socketTimeout);
|
|
}
|
|
|
|
//把TTransport对象打包成池管理的对象PooledObject<TTransport>
|
|
@Override
|
|
public PooledObject<TTransport> wrap(TTransport transport) {
|
|
return new DefaultPooledObject<>(transport);
|
|
}
|
|
}
|
|
|