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

src.com.ibm.as400.access.PoolMaintenance Maven / Gradle / Ivy

There is a newer version: 11.1
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: PoolMaintenance.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2003 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

/**
*  Periodically cleans up pooled connections that have expired.
**/
class PoolMaintenance extends Thread
{
  private boolean run_ = false;        // Whether the maintenance is running.
  private boolean stayAlive_ = true;   // Whether thread should stay alive.
  private transient long lastRun_;     // Last time maintenance was run.
  private transient ConnectionPool pool_;
  private final Object waitLock_ = new Object();

  /**
  *  Constructs a AS400JDBCConnectionPoolMaintenance object.
  *  @param pool The AS400JDBCConnectionPool object.
  **/
  public PoolMaintenance(ConnectionPool pool)
  {
    super("AS400ConnectionPoolMaintenanceThread");
    setDaemon(true);
    pool_ = pool;
    lastRun_ = System.currentTimeMillis();     // Set start time.
  }

  /**
  *  Returns the last time the maintenance was run.
  *  @return The time in milliseconds.
  **/
  public long getLastTime()
  {
    return lastRun_;
  }

  /**
  *  Indicates whether the maintenance thread is running.
  *  @return true if running; false otherwise.
  **/
  public boolean isRunning()
  {
    return run_;
  }

  /**
  *  Runs the pool maintenance cleanup thread.
  **/
  public void run()
  {
    if (Trace.traceOn_)
    {
      Trace.log(Trace.INFORMATION, "Connection pool maintenance daemon is started...");
    }
    run_ = true;

    try
    {
      while (stayAlive_)
      {
        if (run_)
        {
          try
          {
            // sleep for cleanup interval.
            synchronized(waitLock_)
            {
              waitLock_.wait(pool_.getCleanupInterval());
            }
          }
          catch (InterruptedException ie)
          {
            Trace.log(Trace.ERROR, "Connection pool maintenance daemon failed.");
          }
          pool_.cleanupConnections();

          lastRun_ = System.currentTimeMillis();       // set the time of last run.
        }
        else
        {
          try
          {
            // sleep until someone notifies me to continue.
            synchronized(waitLock_)
            {
              waitLock_.wait();
            }
          }
          catch (InterruptedException e)
          {
            Trace.log(Trace.ERROR, "Connection pool maintenance daemon failed.");
          }
        }
      }
    }
    finally
    {
      if (Trace.traceOn_)
      {
        Trace.log(Trace.INFORMATION, "Connection pool maintenance daemon has ended.");
      }
    }
  }

  /**
  *  Sets whether the maintenance thread is running.
  *  Note: Calling this method with 'false' does not terminate the maintenance thread.
  *  To terminate the thread, call shutdown().
  *  @param running true if running; false otherwise.
  **/
  public void setRunning(boolean running)
  {
    if (run_ != running)
    {
      synchronized(waitLock_)
      {
        run_ = running;
        waitLock_.notify();
      }
    }
  }

  /**
  *  Informs the maintenance thread that it should terminate.
  **/
  public void shutdown()
  {
    run_ = false;
    stayAlive_ = false;
    synchronized(waitLock_)
    {
      waitLock_.notify();
    }
  }

}
  




© 2015 - 2024 Weber Informatics LLC | Privacy Policy