From 7b735386b10c464a39d4e0298c99a33f6ae038fe Mon Sep 17 00:00:00 2001 From: Matthew Newhook Date: Fri, 15 Aug 2008 14:47:14 -0230 Subject: added first cut at JDBC demo. --- java/demo/Database/library/ReapThread.java | 102 +++++++++++++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 java/demo/Database/library/ReapThread.java (limited to 'java/demo/Database/library/ReapThread.java') diff --git a/java/demo/Database/library/ReapThread.java b/java/demo/Database/library/ReapThread.java new file mode 100644 index 00000000000..5bef3cd3c50 --- /dev/null +++ b/java/demo/Database/library/ReapThread.java @@ -0,0 +1,102 @@ +// ********************************************************************** +// +// Copyright (c) 2003-2008 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 ReapThread extends Thread +{ + static class SessionProxyPair + { + SessionProxyPair(Demo.SessionPrx p, SessionI s) + { + proxy = p; + session = s; + } + + Demo.SessionPrx proxy; + SessionI session; + } + + ReapThread(Ice.Logger logger) + { + _logger = logger; + } + + synchronized public void + run() + { + while(!_terminated) + { + try + { + wait(1000); + } + catch(InterruptedException e) + { + } + + if(!_terminated) + { + java.util.Iterator 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) + { + _logger.trace("ReapThread", "The session " + s.proxy.ice_getIdentity() + " has timed out."); + s.proxy.destroy(); + p.remove(); + } + } + catch(Ice.ObjectNotExistException e) + { + p.remove(); + } + } + } + } + } + + synchronized public void + terminate() + { + _terminated = true; + notify(); + + // 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 is not + // permitted. + java.util.Iterator p = _sessions.iterator(); + while(p.hasNext()) + { + p.next().session.shutdown(); + } + _sessions.clear(); + } + + synchronized public void + add(SessionPrx proxy, SessionI session) + { + _sessions.add(new SessionProxyPair(proxy, session)); + } + + private final long _timeout = 10 * 1000; // 10 seconds. + private Ice.Logger _logger; + private boolean _terminated = false; + private java.util.List _sessions = new java.util.LinkedList(); +} -- cgit v1.2.3