<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">Hi Graham,<div class=""><br class=""></div><div class="">The short answer is no,TAO currently does not have any sort of a time based active close policy for server side connections. There are connection cache purging strategies, which are triggered when the capacity of the cache is reached. The default strategy is Least Recently Used, which would cover your "dead" clients. The connection cache management is covered in OCI's TAO Developer's Guide and in other documentation. The default connection cache size is 1/2 of ACE's max handles value, which is typically 512, and the default purge percentage is 20%. </div><div class=""><br class=""></div><div class="">It would be possible to add an active close policy which either hooked into the reactor or ran in a separate thread. The reason this isn't there now is that generally quiescent connections are not a problem until you have a lot of them, and there is a way to deal once that becomes the case. Also, time spent scanning the cache is time not spent servicing active clients. Finally, there is the issue of sending CloseConnection messages. TAO servers currently do not do that, so a client may not detect the connection close until it tries to send a new request at which time it receives a COMM_FAILURE exception. Even though your dead clients don't care, the ones that aren't dead ought to have the chance to cleanly reset the connection to the server.</div><div class=""><br class=""></div><div class="">Best regards,</div><div class="">Phil</div><div class=""><br class=""></div><div class=""><div><blockquote type="cite" class=""><div class="">On Feb 21, 2016, at 11:30 AM, graham walsh <<a href="mailto:gjw369@gmail.com" class="">gjw369@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><p dir="ltr" class="">Hi,<br class="">
Form filled in below;<br class="">
TAO VERSION: 2.3.3 <br class="">
ACE VERSION: 6.3.3<br class="">
g++ on linux.</p><p dir="ltr" class="">I've a general question and its specific to the deployed architecture. I've filled out the form below as much as possible but I dont have all the details at hand, heres my question.</p><p dir="ltr" class="">I have a server that has a lot of things connected to it, over IIOP. Everything works fine until;</p><p dir="ltr" class="">1) Certain (java) clients get themselves locked up. They stop reading from their TCP buffers and they are ultimately (brutally) killed off. The admins take care of that.</p><p dir="ltr" class="">2) Until the admins intervene, the client connection to the server is maintaned as expected. The transport on server side does not close the connection down as it has no idea that the client is "dead".</p><p dir="ltr" class="">However, it would be nice if the server could have logic something like this;</p><p dir="ltr" class="">"If I have an idle connection from anything connected to me from machine X, I am going to shut down the connection after 30 seconds of inactivity".</p><p dir="ltr" class="">I'm not sure it TAO/ACE allows this, if it is possible, could somebody direct me to the appropriate API/DOC. The target architecture/application is bog standard CORBA clients and servers. Nothing insanely complicated going on. The above situation arises from time to time and the cient(s) in question (specifically their connections to the server) are a source of concern and I would like to be able to manage things for this specific set of clients server side (as opposed to waiting for the admin guys to kill them off).</p><p dir="ltr" class="">Is there anything like "Close client connections after N ms inactivity" server side?</p><p dir="ltr" class="">thanks in advance.</p><p dir="ltr" class="">G</p><p dir="ltr" class=""> TAO VERSION: 2.3.3<br class="">
ACE VERSION: 6.3.3</p><p dir="ltr" class=""> HOST MACHINE and OPERATING SYSTEM:<br class="">
Linux red had<br class="">
TARGET MACHINE and OPERATING SYSTEM, if different from HOST:<br class="">
COMPILER NAME AND VERSION (AND PATCHLEVEL):<br class="">
g++ - not sure of version but its a supported one.</p><p dir="ltr" class=""> THE $ACE_ROOT/ace/config.h FILE [if you use a link to a platform-<br class="">
specific file, simply state which one]:</p><p dir="ltr" class=""> dont have it here.<br class="">
THE $ACE_ROOT/include/makeinclude/platform_macros.GNU FILE [if you<br class="">
use a link to a platform-specific file, simply state which one<br class="">
(unless this isn't used in this case, e.g., with Microsoft Visual<br class="">
C++)]:<br class="">
<br class="">
dont have it here.<br class="">
CONTENTS OF $ACE_ROOT/bin/MakeProjectCreator/config/default.features<br class="">
(used by MPC when you generate your own makefiles):</p><p dir="ltr" class=""> AREA/CLASS/EXAMPLE AFFECTED:<br class="">
Not a failure<br class="">
DOES THE PROBLEM AFFECT:<br class="">
EXECUTION?<br class="">
connections at runtime.</p><div class=""> <br class="webkit-block-placeholder"></div><p dir="ltr" class=""> SYNOPSIS:<br class="">
how to deal with misbehaving clients holding connections.</p><p dir="ltr" class=""> DESCRIPTION:<br class="">
See above<br class="">
</p>
_______________________________________________<br class="">tao-users mailing list<br class=""><a href="mailto:tao-users@list.isis.vanderbilt.edu" class="">tao-users@list.isis.vanderbilt.edu</a><br class="">http://list.isis.vanderbilt.edu/cgi-bin/mailman/listinfo/tao-users</div></blockquote></div><br class=""><div class="">
<div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class=""><div style="font-size: 12.8px;" class=""><div style="margin: 0px; padding: 0px; border: 0px;" class=""><span style="font-family: arial, helvetica, sans-serif; font-size: large;" class="">--</span></div><div style="margin: 0px; padding: 0px; border: 0px;" class=""><span style="font-family: arial, helvetica, sans-serif; font-size: large;" class="">Phil Mesnier</span><br class=""></div></div><div style="font-size: 12.8px;" class=""><div style="font-size: 12.8px;" class=""><font face="arial, helvetica, sans-serif" size="2" class="">Principal Engineer & Partner</font></div><div style="font-size: 12.8px;" class=""><font face="arial, helvetica, sans-serif" class=""><br class=""></font></div><div style="font-size: 12.8px;" class=""><span style="font-family: arial, helvetica, sans-serif;" class=""><font size="2" color="#000000" class="">OCI | WE ARE SOFTWARE ENGINEERS.</font></span></div><div style="font-size: 12.8px;" class=""><span style="font-family: arial, helvetica, sans-serif; font-size: x-small;" class="">tel +1.314.579.0066 x225</span><br class=""></div><div style="font-size: 12.8px;" class=""><a href="http://ociweb.com/" target="_blank" class="">ociweb.com</a></div><div class=""><br class=""></div></div></div></div><br class="Apple-interchange-newline"></div><br class="Apple-interchange-newline"><br class="Apple-interchange-newline">
</div>
<br class=""></div></body></html>