diff options
author | Matthew Newhook <matthew@zeroc.com> | 2014-08-07 14:36:07 -0230 |
---|---|---|
committer | Matthew Newhook <matthew@zeroc.com> | 2014-08-07 14:36:07 -0230 |
commit | b36ae21c88735cbd2c39c5ccde2572a8fcc4e928 (patch) | |
tree | dfd5eee6e7d61a9c6efcbaabe916639009aaa9af /java/demo/Ice/interrupt/TaskManagerI.java | |
parent | Add @Override where possible, and remove trailing white space. (diff) | |
download | ice-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.java | 56 |
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; +} |