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

scouter.agent.BackJobs Maven / Gradle / Ivy

There is a newer version: 2.20.0
Show newest version
/*
 *  Copyright 2015 the original author or authors. 
 *  @https://github.com/scouter-project/scouter
 *
 *  Licensed under the Apache License, Version 2.0 (the "License"); 
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License. 
 */
package scouter.agent;
import scouter.util.StringEnumer;
import scouter.util.StringKeyLinkedMap;
import scouter.util.ThreadUtil;
public class BackJobs extends Thread {
	private static BackJobs instance = null;
	public final static synchronized BackJobs getInstance() {
		if (instance == null) {
			instance = new BackJobs();
			instance.setDaemon(true);
			instance.setName(ThreadUtil.getName(instance));
			instance.start();
		}
		return instance;
	}
	protected BackJobs() {
	}
	public class JobW {
		Runnable job;
		long lastExTime;
		int interval;
		public JobW(Runnable job, int interval) {
			this.job = job;
			this.interval = interval;
		}
	}
	private StringKeyLinkedMap jobs = new StringKeyLinkedMap();
	/**
	 * 반복적으로 실행할 잡을 등록한다.
	 * 
	 * @param id
	 * @param interval
	 *            - 1000보다 작으면 1000 이 적용된다.
	 * @param job
	 */
	public void put(String id, int interval, Runnable job) {
		jobs.put(id, new JobW(job, interval));
	}
	
	public void remove(String id) {
		jobs.remove(id);
	}
	public void shutdown() {
		running = false;
	}
	private boolean running = true;
	public void run() {
		while (running) {
			ThreadUtil.sleep(1000);
			try {
				process();
			} catch (Throwable t) {
				Logger.println("A109", t);
			}
		}
	}
	private void process() {
		StringEnumer en = jobs.keys();
		while (en.hasMoreElements()) {
			String id = en.nextString();
			JobW jobw = jobs.get(id);
			if (jobw == null)
				continue;
			long now = System.currentTimeMillis();
			if (now >= jobw.lastExTime + jobw.interval) {
				jobw.lastExTime = now;
				try {
					jobw.job.run();
				} catch (Exception e) {
					Logger.println("A110", id + ":" + e);
				}
			}
		}
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy