comparison flys-artifacts/src/main/java/de/intevation/flys/wsplgen/Scheduler.java @ 3818:dc18457b1cef

merged flys-artifacts/pre2.7-2012-03-16
author Thomas Arendsen Hein <thomas@intevation.de>
date Fri, 28 Sep 2012 12:14:59 +0200
parents 368040e5c400
children 453d2d0c4258
comparison
equal deleted inserted replaced
2456:60ab1054069d 3818:dc18457b1cef
1 package de.intevation.flys.wsplgen;
2
3 import java.util.HashMap;
4 import java.util.Map;
5 import java.util.concurrent.Future;
6 import java.util.concurrent.ScheduledThreadPoolExecutor;
7
8 import org.apache.log4j.Logger;
9
10 import de.intevation.artifacts.CallContext;
11
12 import de.intevation.flys.artifacts.model.WSPLGENJob;
13
14
15 /**
16 * The Scheduler is used to retrieve new WSPLGENJob. The incoming jobs are added
17 * to a ScheduledThreadPoolExecutor. This thread pool has a number of worker
18 * threads that processes the WSPLGENJobs. The number of worker threads can be
19 * set using a System property <i>wsplgen.max.threads</i> ; its default value is
20 * 1.
21 *
22 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
23 */
24 public class Scheduler {
25
26 private class FutureJob {
27 public Future future;
28 public WSPLGENJob job;
29
30 public FutureJob(Future future, WSPLGENJob job) {
31 this.future = future;
32 this.job = job;
33 }
34 }
35
36 public static final int MAX_WSPLGEN_PROCESSES =
37 Integer.getInteger("wsplgen.max.threads", 1);
38
39
40 protected ScheduledThreadPoolExecutor pool;
41 protected Map<String, FutureJob> jobs;
42
43
44 private static Scheduler INSTANCE;
45
46 private static final Logger logger = Logger.getLogger(Scheduler.class);
47
48
49
50 private Scheduler() {
51 jobs = new HashMap<String, FutureJob>();
52 pool = new ScheduledThreadPoolExecutor(MAX_WSPLGEN_PROCESSES);
53 }
54
55
56 public static Scheduler getInstance() {
57 if (INSTANCE == null) {
58 logger.info("Create new WSPLGEN Scheduler...");
59
60 INSTANCE = new Scheduler();
61 }
62
63 return INSTANCE;
64 }
65
66
67 public void addJob(final WSPLGENJob job) {
68 synchronized (jobs) {
69 WSPLGENFuture f = new WSPLGENFuture(new WSPLGENCallable(this, job));
70 pool.execute(f);
71
72 jobs.put(job.getArtifact().identifier(), new FutureJob(f, job));
73
74 logger.info("New WSPLGEN job successfully added.");
75 }
76 }
77
78
79 /**
80 * Cancels a running (or queued) job.
81 *
82 * @param jobId The id of the job (which is the identifier of an Artifact).
83 */
84 public void cancelJob(String jobId) {
85 logger.debug("Search job in queue: " + jobId);
86
87 synchronized (jobs) {
88 FutureJob fj = jobs.get(jobId);
89
90 if (fj != null) {
91 logger.info("Try to cancel job: " + jobId);
92
93 fj.future.cancel(true);
94
95 removeJob(jobId);
96
97 fj.job.getCallContext().afterBackground(
98 CallContext.STORE);
99
100 logger.info("Canceled job: " + jobId);
101 }
102 }
103 }
104
105
106 protected void removeJob(String id) {
107 synchronized (jobs) {
108 jobs.remove(id);
109 }
110 }
111 }
112 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org