com.aoindustries.aoserv.client.SocketConnectionPool Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aoserv-client Show documentation
Show all versions of aoserv-client Show documentation
Java client for the AOServ Platform.
/*
* aoserv-client - Java client for the AOServ Platform.
* Copyright (C) 2001-2009, 2016, 2017, 2018, 2019, 2020 AO Industries, Inc.
* [email protected]
* 7262 Bull Pen Cir
* Mobile, AL 36695
*
* This file is part of aoserv-client.
*
* aoserv-client is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* aoserv-client is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with aoserv-client. If not, see .
*/
package com.aoindustries.aoserv.client;
import com.aoindustries.aoserv.client.schema.Table;
import com.aoindustries.io.AOPool;
import java.io.IOException;
import java.io.InterruptedIOException;
import java.sql.SQLException;
import java.util.logging.Logger;
/**
* Connections made by TCPConnector
or any
* of its derivatives are pooled and reused.
*
* @see TCPConnector
*
* @author AO Industries, Inc.
*/
final class SocketConnectionPool extends AOPool {
public static final int DELAY_TIME=3*60*1000;
public static final int MAX_IDLE_TIME=15*60*1000;
private final TCPConnector connector;
SocketConnectionPool(TCPConnector connector, Logger logger) {
super(
DELAY_TIME,
MAX_IDLE_TIME,
// TODO: EncodeURLComponent this and AOServConnector?
SocketConnectionPool.class.getName() + "?hostname=" + connector.hostname + "&port=" + connector.port + "&connectAs=" + connector.connectAs + "&authenticateAs=" + connector.authenticateAs,
connector.poolSize,
connector.maxConnectionAge,
logger
);
this.connector=connector;
}
@Override
protected void close(SocketConnection conn) {
conn.close();
}
@Override
protected SocketConnection getConnectionObject() throws InterruptedIOException, IOException {
return new SocketConnection(connector);
}
@Override
protected boolean isClosed(SocketConnection conn) {
return conn.isClosed();
}
/**
* Avoid repeated copies.
*/
private static final int numTables = Table.TableID.values().length;
@Override
@SuppressWarnings("deprecation")
protected void printConnectionStats(Appendable out, boolean isXhtml) throws IOException {
try {
// Create statistics on the caches
int totalLoaded=0;
int totalCaches=0;
int totalActive=0;
int totalHashed=0;
int totalIndexed=0;
int totalRows=0;
for(AOServTable,?> table : connector.getTables()) {
totalLoaded++;
if(table instanceof CachedTable,?>) {
totalCaches++;
int columnCount=table.getTableSchema().getSchemaColumns(connector).size();
CachedTable,?> cached=(CachedTable,?>)table;
if(cached.isLoaded()) {
totalActive++;
for(int d=0;d) {
totalCaches++;
int columnCount=table.getTableSchema().getSchemaColumns(connector).size();
GlobalTable,?> global=(GlobalTable,?>)table;
if(global.isLoaded()) {
totalActive++;
for(int d=0;d\n"
+ " AOServ Tables \n"
+ " \n");
super.printConnectionStats(out, isXhtml);
out.append(" Total Tables: ").append(Integer.toString(numTables)).append(" \n"
+ " Loaded: ").append(Integer.toString(totalLoaded)).append(" \n"
+ " Caches: ").append(Integer.toString(totalCaches)).append(" \n"
+ " Active: ").append(Integer.toString(totalActive)).append(" \n"
+ " Hashed: ").append(Integer.toString(totalHashed)).append(" \n"
+ " Indexes: ").append(Integer.toString(totalIndexed)).append(" \n"
+ " Total Rows: ").append(Integer.toString(totalRows)).append(" \n"
+ " \n"
+ "\n");
if(isXhtml) out.append("
\n");
else out.append("
\n");
out.append("\n"
+ " \n"
+ " TCP Connection Pool \n"
+ " \n");
super.printConnectionStats(out, isXhtml);
out.append(" Host: ");
com.aoindustries.util.EncodingUtils.encodeHtml(connector.hostname, out, isXhtml);
out.append(" \n"
+ " Port: ").append(Integer.toString(connector.port.getPort())).append(" \n"
+ " Connected As: ");
com.aoindustries.util.EncodingUtils.encodeHtml(connector.connectAs, out, isXhtml);
out.append(" \n"
+ " Authenticated As: ");
com.aoindustries.util.EncodingUtils.encodeHtml(connector.authenticateAs, out, isXhtml);
out.append(" \n"
+ " Password: ");
String password=connector.password;
int len = Math.max(password.length(), 8);
for(int c=0;c \n");
} catch(SQLException err) {
throw new IOException(err);
}
}
@Override
protected void resetConnection(SocketConnection conn) {
}
@Override
protected IOException newException(String message, Throwable cause) {
IOException err=new IOException(message);
if(cause!=null) err.initCause(cause);
return err;
}
@Override
protected InterruptedIOException newInterruptedException(String message, Throwable cause) {
InterruptedIOException err = new InterruptedIOException(message);
if(cause!=null) err.initCause(cause);
return err;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy