summaryrefslogtreecommitdiff
path: root/java/demo/Ice/interrupt/TaskManagerI.java
diff options
context:
space:
mode:
authorMatthew Newhook <matthew@zeroc.com>2014-08-07 14:36:07 -0230
committerMatthew Newhook <matthew@zeroc.com>2014-08-07 14:36:07 -0230
commitb36ae21c88735cbd2c39c5ccde2572a8fcc4e928 (patch)
treedfd5eee6e7d61a9c6efcbaabe916639009aaa9af /java/demo/Ice/interrupt/TaskManagerI.java
parentAdd @Override where possible, and remove trailing white space. (diff)
downloadice-b36ae21c88735cbd2c39c5ccde2572a8fcc4e928.tar.bz2
ice-b36ae21c88735cbd2c39c5ccde2572a8fcc4e928.tar.xz
ice-b36ae21c88735cbd2c39c5ccde2572a8fcc4e928.zip
ICE-1593 Handling thread interrupts in Java
- Added Ice.BackgroundIO property to perform all IO in a non-user thread. This makes Ice for Java interrupt safe. This is implemented by the QueueRequestHanbler. - EndpointHostResolver now uses an executor instead of a thread. - Added java/demo/Ice/interrupt and java/test/Ice/interrupt. - Made several changes that must be ported to C++ & C#. - InvocationTimeout exceptions can hang forever. - Connection establishment is always asynchronous. - RequestHandler.requestTimeout and asyncRequestTimeout have been renamed to requestCancel and asyncRequestCancel.
Diffstat (limited to 'java/demo/Ice/interrupt/TaskManagerI.java')
-rw-r--r--java/demo/Ice/interrupt/TaskManagerI.java56
1 files changed, 56 insertions, 0 deletions
diff --git a/java/demo/Ice/interrupt/TaskManagerI.java b/java/demo/Ice/interrupt/TaskManagerI.java
new file mode 100644
index 00000000000..a0cf5886d4c
--- /dev/null
+++ b/java/demo/Ice/interrupt/TaskManagerI.java
@@ -0,0 +1,56 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2014 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+import java.util.concurrent.ExecutorService;
+
+import Demo.*;
+
+public class TaskManagerI extends _TaskManagerDisp
+{
+ public TaskManagerI(ExecutorService executor)
+ {
+ _executor = executor;
+ }
+
+ @Override
+ public void
+ run(int id, Ice.Current current)
+ {
+ System.out.println("starting task " + id);
+ // Sleep for 10 seconds.
+ try
+ {
+ Thread.sleep(10000);
+ System.out.println("stopping task " + id);
+ }
+ catch(InterruptedException ex)
+ {
+ //
+ // We are done, the server is shutting down.
+ //
+ System.out.println("interrupted task " + id);
+ }
+ }
+
+ @Override
+ public void
+ shutdown(Ice.Current current)
+ {
+ System.out.println("Shutting down...");
+ //
+ // Call shutdownNow on the executor. This interrupts all
+ // executor threads causing any running upcalls to terminate
+ // quickly.
+ //
+ _executor.shutdownNow();
+ current.adapter.getCommunicator().shutdown();
+ }
+
+ private ExecutorService _executor;
+}