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

com.aoindustries.aoserv.client.SocketConnectionPool Maven / Gradle / Ivy

There is a newer version: 1.92.0
Show newest version
/*
 * 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" + " \n" + " \n"); super.printConnectionStats(out, isXhtml); out.append(" \n" + " \n" + " \n" + " \n" + " \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; } }









TCP Connection Pool
Host:"); com.aoindustries.util.EncodingUtils.encodeHtml(connector.hostname, out, isXhtml); out.append("
Port:").append(Integer.toString(connector.port.getPort())).append("
Connected As:"); com.aoindustries.util.EncodingUtils.encodeHtml(connector.connectAs, out, isXhtml); out.append("
Authenticated As:"); com.aoindustries.util.EncodingUtils.encodeHtml(connector.authenticateAs, out, isXhtml); out.append("
Password:"); String password=connector.password; int len = Math.max(password.length(), 8); for(int c=0;c