Kieker 1.11

kieker.monitoring.writer.filesystem.async
Class AbstractZipWriterThread

java.lang.Object
  extended by java.lang.Thread
      extended by kieker.monitoring.writer.AbstractAsyncThread
          extended by kieker.monitoring.writer.filesystem.async.AbstractZipWriterThread
All Implemented Interfaces:
java.lang.Runnable
Direct Known Subclasses:
AsciiZipWriterThread, BinaryZipWriterThread

public abstract class AbstractZipWriterThread
extends AbstractAsyncThread

Since:
1.7
Author:
Jan Waller

Nested Class Summary
 
Nested classes/interfaces inherited from class java.lang.Thread
java.lang.Thread.State, java.lang.Thread.UncaughtExceptionHandler
 
Field Summary
protected  java.lang.String fileExtension
           
protected  java.util.zip.ZipOutputStream zipOutputStream
          The output stream pointing to the defined zip file.
 
Fields inherited from class kieker.monitoring.writer.AbstractAsyncThread
monitoringController
 
Fields inherited from class java.lang.Thread
MAX_PRIORITY, MIN_PRIORITY, NORM_PRIORITY
 
Constructor Summary
AbstractZipWriterThread(IMonitoringController monitoringController, java.util.concurrent.BlockingQueue<IMonitoringRecord> writeQueue, StringMappingFileWriter mappingFileWriter, java.lang.String path, int maxEntriesInFile, int level)
          Create a new AbstractZipWriterThread.
 
Method Summary
protected  void cleanup()
          Inheriting classes should implement this method to do some cleanup work like, for example, closing open connections.
protected abstract  void cleanupFinal()
          Inheriting classes should implement this method to perform a final cleanup.
protected abstract  void cleanupForNextEntry()
          Inheriting classes should implement this method to perform a cleanup for the next entry.
protected  void consume(IMonitoringRecord monitoringRecord)
          Inheriting classes should implement this method to consume the given record by, for example, sending it to a JMS client or by writing it to the file sysytem.
protected  java.lang.String getFilename()
          Return the filename of a log file.
 java.lang.String toString()
          Returns a human-readable information string about the writer's configuration and state.
protected abstract  void write(IMonitoringRecord monitoringRecord)
          Inheriting classes should implement this method to actually write the monitoring record.
 
Methods inherited from class kieker.monitoring.writer.AbstractAsyncThread
initShutdown, isFinished, run
 
Methods inherited from class java.lang.Thread
activeCount, checkAccess, clone, countStackFrames, currentThread, destroy, dumpStack, enumerate, getAllStackTraces, getContextClassLoader, getDefaultUncaughtExceptionHandler, getId, getName, getPriority, getStackTrace, getState, getThreadGroup, getUncaughtExceptionHandler, holdsLock, interrupt, interrupted, isAlive, isDaemon, isInterrupted, join, join, join, resume, setContextClassLoader, setDaemon, setDefaultUncaughtExceptionHandler, setName, setPriority, setUncaughtExceptionHandler, sleep, sleep, start, stop, stop, suspend, yield
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Field Detail

fileExtension

protected java.lang.String fileExtension

zipOutputStream

protected final java.util.zip.ZipOutputStream zipOutputStream
The output stream pointing to the defined zip file.

Constructor Detail

AbstractZipWriterThread

public AbstractZipWriterThread(IMonitoringController monitoringController,
                               java.util.concurrent.BlockingQueue<IMonitoringRecord> writeQueue,
                               StringMappingFileWriter mappingFileWriter,
                               java.lang.String path,
                               int maxEntriesInFile,
                               int level)
                        throws java.io.IOException
Create a new AbstractZipWriterThread.

Parameters:
monitoringController - the monitoring controller accessed by this thread
writeQueue - the queue where the writer fetches its records from
mappingFileWriter - writer for the mapping file (the file where class names are mapped to record ids)
path - location where to files should go to (the path must point to a directory)
maxEntriesInFile - limit for the number of records per log file
level - compression level
Throws:
java.io.IOException - when file operation fails
Method Detail

cleanup

protected final void cleanup()
Inheriting classes should implement this method to do some cleanup work like, for example, closing open connections.

Specified by:
cleanup in class AbstractAsyncThread

getFilename

protected final java.lang.String getFilename()
Return the filename of a log file.

Returns:
log file name

consume

protected final void consume(IMonitoringRecord monitoringRecord)
                      throws java.lang.Exception
Description copied from class: AbstractAsyncThread
Inheriting classes should implement this method to consume the given record by, for example, sending it to a JMS client or by writing it to the file sysytem.

Specified by:
consume in class AbstractAsyncThread
Parameters:
monitoringRecord - The record to consume.
Throws:
java.lang.Exception - Indicates that something went wrong during the consumption.

write

protected abstract void write(IMonitoringRecord monitoringRecord)
                       throws java.io.IOException
Inheriting classes should implement this method to actually write the monitoring record.

Parameters:
monitoringRecord - The record to be written.
Throws:
java.io.IOException - If something went wrong during the writing.

cleanupForNextEntry

protected abstract void cleanupForNextEntry()
                                     throws java.io.IOException
Inheriting classes should implement this method to perform a cleanup for the next entry.

Throws:
java.io.IOException - If something went wrong during the cleanup.

cleanupFinal

protected abstract void cleanupFinal()
                              throws java.io.IOException
Inheriting classes should implement this method to perform a final cleanup.

Throws:
java.io.IOException - If something went wrong during the cleanup.

toString

public final java.lang.String toString()
Description copied from class: AbstractAsyncThread
Returns a human-readable information string about the writer's configuration and state.

Overrides:
toString in class AbstractAsyncThread
Returns:
the information string.

Kieker 1.11

Copyright 2015 Kieker Project, http://kieker-monitoring.net