1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
|
// **********************************************************************
//
// Copyright (c) 2003-2009 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)
{
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;
}
ReapThread(Ice.Logger logger, long timeout)
{
_logger = logger;
_timeout = timeout;
}
synchronized public void
run()
{
while(!_terminated)
{
try
{
wait((_timeout / 2) * 1000);
}
catch(InterruptedException e)
{
}
if(!_terminated)
{
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("ReapThread", "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()
{
_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 are not
// permitted.
java.util.Iterator<SessionProxyPair> 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));
}
synchronized public void
add(Glacier2.SessionPrx proxy, SessionI session)
{
_sessions.add(new SessionProxyPair(proxy, session));
}
private final long _timeout; // Seconds.
private Ice.Logger _logger;
private boolean _terminated = false;
private java.util.List<SessionProxyPair> _sessions = new java.util.LinkedList<SessionProxyPair>();
}
|