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

examples.nistgoodies.threadaudit.ThreadAudit Maven / Gradle / Ivy

There is a newer version: 1.3.0-91
Show newest version
package examples.nistgoodies.threadaudit;

import gov.nist.javax.sip.stack.SIPTransactionStack;

import javax.sip.*;
import java.util.Properties;
import java.util.Timer;
import java.util.TimerTask;

/**
 * This example demonstrates how an application can monitor
 * the health of the internal threads of the SIP Stack.
 *
 * This code is in the public domain.
 *
 * @author R. Borba (Natural Convergence)
 *
 */
public class ThreadAudit {

    /// SIP Stack objects
    private static SipStack sipStack;
    private static ListeningPoint listeningPoint;

    /// Test timer
    private static Timer timer = new Timer();

    /// Interval between thread audits
    private static long auditIntervalInMillis;

    /// Initializes the stack and starts the periodic audit
    public static void init(boolean enableThreadAudit, long auditInterval) {
        // Save the audit interval for future use
        auditIntervalInMillis = auditInterval;

        /// Initialize the stack properties
        Properties properties = new Properties();
        properties.setProperty("javax.sip.STACK_NAME", "Thread Audit Sample");
        if (enableThreadAudit) {
            // That's all we need to do in order to enable the thread auditor
            properties.setProperty("gov.nist.javax.sip.THREAD_AUDIT_INTERVAL_IN_MILLISECS",
                                    String.valueOf(auditInterval));
        }
        System.out.println("Thread Audit is " + (enableThreadAudit ? "enabled" : "disabled"));

        // Create and initialize the SIP Stack
        initSipStack(properties);

        // Start monitoring the health of the internal threads
        startThreadAudit();

        // Sleep for a while so we can see some good audit reports being generated
        sleep(4 * auditIntervalInMillis);

        // Kill one of the internal threads of the SIP stack so we can detect it in the next audit
        System.out.println("Killing one of the internal threads on purpose to see if the thread auditor detects it");
        try {
            sipStack.deleteListeningPoint(listeningPoint);
        } catch (ObjectInUseException e) {
            System.err.println("Failed to delete UDP listening point");
            e.printStackTrace();
            System.exit(0);
        }

        // Sleep again to see if we're able to detect the listening point thread going away
        sleep(4 * auditIntervalInMillis);

        System.out.println("Done!");
        System.exit(0);
    }

    /// Creates and initializes the SIP Stack
    private static void initSipStack(Properties properties)
    {
        // Create the SIP Stack
        SipFactory l_oSipFactory = SipFactory.getInstance();
        l_oSipFactory.setPathName("gov.nist");
        try {
            sipStack = l_oSipFactory.createSipStack(properties);
        } catch (PeerUnavailableException e) {
            System.err.println("could not find \"gov.nist.jain.protocol.ip.sip.SipStackImpl\" in the classpath");
            e.printStackTrace();
            System.err.println(e.getMessage());
            System.exit(0);
        }

        // Create a UDP listening point
        try {
            listeningPoint = sipStack.createListeningPoint("127.0.0.1", 5060, "UDP");
        } catch (Exception e) {
            System.err.println("Failed to create UDP listening point");
            e.printStackTrace();
            System.exit(0);
        }
    }

    /// Sleeps for a while
    private static void sleep(long millis) {
        try {
            Thread.sleep(millis);
        } catch (InterruptedException e) {
            System.err.println("Can't sleep");
            e.printStackTrace();
            System.exit(0);
        }
    }

    // Kicks off the periodic audit
    private static void startThreadAudit()
    {
        /// Timer class used to periodically audit the stack
        class AuditTimer extends TimerTask {
            /// Action to be performed by this timer task
            public final void run() {
                // That's all we need to do in order to check if the internal threads of the stack are healthy
                String auditReport = ((SIPTransactionStack) sipStack).getThreadAuditor().auditThreads();
                if (auditReport != null) {
                    System.out.println("--> RED ALERT!!! " + auditReport);
                } else {
                    System.out.println("--> Internal threads of the stack appear to be healthy...");
                }

                // Schedule the next audit
                timer.schedule(new AuditTimer(), auditIntervalInMillis);
            }
        }

        // Kick off the audit timer
        timer.schedule(new AuditTimer(), auditIntervalInMillis);
    }

    /// Entry point
    public static void main(String[] args) throws Exception {
        ThreadAudit.init(true, 5000);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy