/* * Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com * The software in this package is published under the terms of the CPAL v1.0 * license, a copy of which has been included with this distribution in the * LICENSE.txt file. */ package org.mule.runtime.module.deployment.internal; import org.mule.runtime.core.util.concurrent.LoggingUncaughtExceptionHandler; import java.util.concurrent.ThreadFactory; import java.util.concurrent.atomic.AtomicInteger; public class ArtifactDeployerMonitorThreadFactory implements ThreadFactory { static final AtomicInteger poolNumber = new AtomicInteger(1); final ThreadGroup group; final AtomicInteger threadNumber = new AtomicInteger(1); final String namePrefix; public ArtifactDeployerMonitorThreadFactory() { SecurityManager s = System.getSecurityManager(); group = (s != null) ? s.getThreadGroup() : Thread.currentThread().getThreadGroup(); namePrefix = String.format("Mule.app.deployer.monitor.%d.thread.", poolNumber.getAndIncrement()); } @Override public Thread newThread(Runnable r) { Thread t = new Thread(group, r, namePrefix + threadNumber.getAndIncrement(), 0); // make sure it's non-daemon, allows for an 'idle' state of Mule by preventing early termination t.setDaemon(false); t.setPriority(Thread.MIN_PRIORITY); t.setUncaughtExceptionHandler(new LoggingUncaughtExceptionHandler()); return t; } }