diff options
Diffstat (limited to 'java/demo/Database/library/ReapTask.java')
-rw-r--r-- | java/demo/Database/library/ReapTask.java | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/java/demo/Database/library/ReapTask.java b/java/demo/Database/library/ReapTask.java new file mode 100644 index 00000000000..3ded348c1a6 --- /dev/null +++ b/java/demo/Database/library/ReapTask.java @@ -0,0 +1,108 @@ +// ********************************************************************** +// +// 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 Demo.*; + +class ReapTask implements Runnable +{ + static class SessionProxyPair + { + SessionProxyPair(Demo.SessionPrx p, SessionI s) + { + glacier2proxy = null; + proxy = p; + session = s; + } + + SessionProxyPair(Glacier2.SessionPrx p, SessionI s) + { + glacier2proxy = p; + proxy = null; + session = s; + } + + Glacier2.SessionPrx glacier2proxy; + Demo.SessionPrx proxy; + SessionI session; + } + + ReapTask(Ice.Logger logger, long timeout) + { + _logger = logger; + _timeout = timeout; + } + + synchronized public void + run() + { + java.util.Iterator<SessionProxyPair> p = _sessions.iterator(); + while(p.hasNext()) + { + SessionProxyPair s = p.next(); + try + { + // + // Session destruction may take time in a + // real-world example. Therefore the current time + // is computed for each iteration. + // + if((System.currentTimeMillis() - s.session.timestamp()) > _timeout * 1000) + { + _logger.trace("ReapTask", "The session " + + s.proxy.ice_getCommunicator().identityToString(s.proxy.ice_getIdentity()) + + " has timed out."); + if(s.proxy != null) + { + s.proxy.destroy(); + } + else + { + s.glacier2proxy.destroy(); + } + p.remove(); + } + } + catch(Ice.ObjectNotExistException e) + { + p.remove(); + } + } + } + + synchronized public void + terminate() + { + // Destroy each of the sessions, releasing any resources they + // may hold. This calls directly on the session, not via the + // proxy since terminate() is called after the communicator is + // shutdown, which means calls on collocated objects are not + // permitted. + for(SessionProxyPair p : _sessions) + { + p.session.shutdown(); + } + _sessions.clear(); + } + + synchronized public void + add(SessionPrx proxy, SessionI session) + { + _sessions.add(new SessionProxyPair(proxy, session)); + } + + synchronized public void + add(Glacier2.SessionPrx proxy, SessionI session) + { + _sessions.add(new SessionProxyPair(proxy, session)); + } + + private final long _timeout; + private Ice.Logger _logger; + private java.util.List<SessionProxyPair> _sessions = new java.util.LinkedList<SessionProxyPair>(); +} |