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

com.nitorcreations.willow.deployer.statistics.ThreadDumpStatisticsSender Maven / Gradle / Ivy

There is a newer version: 2.0.2
Show newest version
package com.nitorcreations.willow.deployer.statistics;

import java.io.IOException;
import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;
import java.util.Properties;
import java.util.logging.Level;
import java.util.logging.Logger;

import javax.inject.Named;
import javax.management.MBeanServerConnection;

import com.nitorcreations.willow.messages.ThreadDumpMessage;

/**
 * Statistics sender for sending thread dumps.
 * Takes a thread dump of the child (via JMX) at specified intervals
 * (default 1 second) and sends it as JSON to the statistics server.
 *
 * @author Mikko Tommila
 */
@Named("threaddump")
public class ThreadDumpStatisticsSender extends AbstractJMXStatisticsSender {
  private Logger logger = Logger.getLogger(getClass().getName());
  private long interval;

  @Override
  public void setProperties(Properties properties) {
    super.setProperties(properties);
    this.interval = Long.parseLong(properties.getProperty("interval", "1000"));
  }

  @Override
  public void execute() {
    for (String childName : getChildren()) {
      try {
        ThreadMXBean threadMXBean = getThreadMXBean(childName);
        ThreadInfo[] threadInfo = threadMXBean.dumpAllThreads(threadMXBean.isObjectMonitorUsageSupported(), threadMXBean.isSynchronizerUsageSupported());
        ThreadDumpMessage threadDumpMessage = new ThreadDumpMessage(threadInfo);
        threadDumpMessage.addTags("category_threaddump_" + childName);
        transmitter.queue(threadDumpMessage);
      } catch (IOException ie) {
        logger.log(Level.INFO, "Cannot get thread management bean of child process", ie);
      }
    }
    try {
      Thread.sleep(this.interval);
    } catch (InterruptedException ie) {
      logger.log(Level.INFO, "Sleep was interrupted", ie);
    }
    if (!running.get()) {
      stop();
    }
  }

  private ThreadMXBean getThreadMXBean(String childName) throws IOException {
    MBeanServerConnection connection = getMBeanServerConnection(childName);
    ThreadMXBean threadMXBean = ManagementFactory.newPlatformMXBeanProxy(connection , ManagementFactory.THREAD_MXBEAN_NAME, ThreadMXBean.class);
    return threadMXBean;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy