annotate servlet/src/digilib/servlet/DigilibManager.java @ 290:5d0c0da080ec gen2 scaleable_1

digilib servlet version 2 ("scaleable digilib") - first stab at using thread pools to limit resource use - using Dug Leas util.concurrent - doesn't mix with tomcat :-(
author robcast
date Thu, 21 Oct 2004 20:53:37 +0200
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
290
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
1 /* DigilibManager.java -- work queue manager
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
2 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
3 * Digital Image Library servlet components
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
4 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
5 * Copyright (C) 2004 Robert Casties (robcast@mail.berlios.de)
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
6 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
7 * This program is free software; you can redistribute it and/or modify it
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
8 * under the terms of the GNU General Public License as published by the Free
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
9 * Software Foundation; either version 2 of the License, or (at your option)
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
10 * any later version.
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
11 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
12 * Please read license.txt for the full details. A copy of the GPL may be found
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
13 * at http://www.gnu.org/copyleft/lgpl.html
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
14 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License along with
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
16 * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
17 * Place, Suite 330, Boston, MA 02111-1307 USA
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
18 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
19 * Created on 18.10.2004
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
20 */
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
21
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
22 package digilib.servlet;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
23
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
24 import EDU.oswego.cs.dl.util.concurrent.BoundedBuffer;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
25 import EDU.oswego.cs.dl.util.concurrent.Executor;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
26 import EDU.oswego.cs.dl.util.concurrent.PooledExecutor;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
27
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
28 /** work queue manager.
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
29 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
30 * @author casties
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
31 *
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
32 */
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
33 public class DigilibManager implements Executor {
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
34
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
35 private PooledExecutor workerQueue = null;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
36
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
37 private BoundedBuffer jobQueue = null;
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
38
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
39 /**
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
40 * @param numFastLanes
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
41 * @param numSlowLanes
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
42 */
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
43 public DigilibManager(int numLanes, int queueMax) {
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
44 super();
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
45
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
46 // create job queue
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
47 jobQueue = new BoundedBuffer(queueMax);
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
48 // create work queue
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
49 workerQueue = new PooledExecutor(jobQueue, numLanes);
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
50 workerQueue.abortWhenBlocked();
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
51
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
52 }
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
53
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
54
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
55 public void execute(Runnable worker) throws InterruptedException {
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
56 workerQueue.execute(worker);
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
57 }
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
58
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
59 public int getQueueSize() {
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
60 return jobQueue.size();
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
61 }
5d0c0da080ec digilib servlet version 2 ("scaleable digilib")
robcast
parents:
diff changeset
62 }