package org.rhq.server.metrics; import java.util.concurrent.ThreadFactory; import java.util.concurrent.atomic.AtomicInteger; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * @author John Sanda */ public class StorageClientThreadFactory implements ThreadFactory, Thread.UncaughtExceptionHandler { private final Log log; private AtomicInteger threadNumber = new AtomicInteger(0); private String poolName; public StorageClientThreadFactory() { this("StorageClientThreadPool"); } public StorageClientThreadFactory(String name) { this.poolName = name; log = LogFactory.getLog(poolName); } @Override public Thread newThread(Runnable r) { Thread t = new Thread(r, poolName + "-" + threadNumber.getAndIncrement()); t.setDaemon(false); t.setUncaughtExceptionHandler(this); return t; } @Override public void uncaughtException(Thread t, Throwable e) { log.error("Uncaught exception on scheduled thread [" + t.getName() + "]", e); } }