<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
{font-family:Consolas;
panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
pre
{mso-style-priority:99;
mso-style-link:"HTML Preformatted Char";
margin:0in;
margin-bottom:.0001pt;
font-size:10.0pt;
font-family:"Courier New";}
p.msonormal0, li.msonormal0, div.msonormal0
{mso-style-name:msonormal;
mso-margin-top-alt:auto;
margin-right:0in;
mso-margin-bottom-alt:auto;
margin-left:0in;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
span.HTMLPreformattedChar
{mso-style-name:"HTML Preformatted Char";
mso-style-priority:99;
mso-style-link:"HTML Preformatted";
font-family:Consolas;}
span.EmailStyle21
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head><body lang="EN-IN" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Thanks Johnny.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">I’ve also tried with the ACE 6.5.0, but it did not help. I was still observing the same issues as reported in the PRF.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Regards,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US">Nagesh<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span lang="EN-US">From:</span></b><span lang="EN-US"> Johnny Willemsen <jwillemsen@remedy.nl>
<br>
<b>Sent:</b> Monday, April 13, 2020 6:00 PM<br>
<b>To:</b> Somisetty, Nagesh <NSomisetty@tnsi.com>; ace-bugs@list.isis.vanderbilt.edu<br>
<b>Cc:</b> Zhao, Changchun <czhao@tnsi.com>; Santhappanavara, Sharath <SSanthappanavara@tnsi.com>; Gupta, Ajay <agupta@tnsi.com><br>
<b>Subject:</b> Re: [ace-bugs] ACE_Svc_Handler handle_input not called in some scenarios randomly when using ACE_SSL_Sock_Stream and ACE_Acceptor<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<p>Hi,<o:p></o:p></p>
<p>Thanks for using the PRF form. 6.2.0 is already pretty old, can you trie ACE 6.5.8 which you can download from
<a href="http://download.dre.vanderbilt.edu">
http://download.dre.vanderbilt.edu</a>, that is the most recent micro release.<o:p></o:p></p>
<p>Regards,<o:p></o:p></p>
<pre>Johnny Willemsen<o:p></o:p></pre>
<pre>Remedy IT<o:p></o:p></pre>
<pre><a href="http://www.remedy.nl">http://www.remedy.nl</a><o:p></o:p></pre>
<div>
<p class="MsoNormal">On 4/13/20 11:28 AM, Somisetty, Nagesh wrote:<o:p></o:p></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal" style="margin-bottom:12.0pt">ACE VERSION: 6.2.0<br>
<br>
HOST MACHINE and OPERATING SYSTEM: RHEL Server 6.8<br>
If on Windows based OS's, which version of WINSOCK do you<br>
use?:<br>
<br>
TARGET MACHINE and OPERATING SYSTEM, if different from HOST: RHEL Server 6.8<br>
COMPILER NAME AND VERSION (AND PATCHLEVEL): g++ (GCC) 4.4.7 20120313 (Red Hat 4.4.7-3)<br>
<br>
THE $ACE_ROOT/ace/config.h FILE [if you use a link to a platform-<br>
specific file, simply state which one]:<br>
<br>
THE $ACE_ROOT/include/makeinclude/platform_macros.GNU FILE [if you<br>
use a link to a platform-specific file, simply state which one<br>
(unless this isn't used in this case, e.g., with Microsoft Visual<br>
C++)]:<br>
<br>
CONTENTS OF $ACE_ROOT/bin/MakeProjectCreator/config/default.features<br>
(used by MPC when you generate your own makefiles):<br>
<br>
AREA/CLASS/EXAMPLE AFFECTED:<br>
ACE_Svc_Handler handle_input not called (in some cases) when using ACE_SSL_Sock_Stream and ACE_Acceptor<br>
<br>
DOES THE PROBLEM AFFECT:<br>
COMPILATION?<br>
LINKING?<br>
On Unix systems, did you run make realclean first?<br>
EXECUTION?<br>
OTHER (please specify)?<br>
Described problem affects the EXECUTION of the application<br>
<br>
SYNOPSIS:<br>
ACE_Svc_Handler handle_input not called in some scenarios when using ACE_Acceptor and ACE_SSL_Sock_Stream<br>
<br>
DESCRIPTION:<br>
1) I have an ACE_Acceptor based server application that works either as a TCP or TLS server.<br>
2) The TCP and TLS services are defined as below,<br>
typedef ACE_Acceptor<TCPServer, ACE_SOCK_ACCEPTOR> TCPService;<br>
typedef ACE_Acceptor<TLSServer, ACE_SSL_SOCK_ACCEPTOR> TLSService;<br>
where TCPServer and TLSServer are derived from ACE_Svc_Handler as below<br>
class TCPServer : public ACE_Svc_Handler<ACE_SOCK_STREAM, ACE_NULL_SYNCH><br>
class TLSServer : public ACE_Svc_Handler<ACE_SSL_SOCK_STREAM, ACE_NULL_SYNCH><br>
Both these TCPServer and TLSServer have implemented the handle_input callbacks for handling of incoming events from the socket.<br>
3) Our observation is that while using the TLSServer, we see that the handle_input is not called in a few cases as listed below.<br>
a) When the application attempts to do a peer().recv(buff,len) on receiving a handle_input and the application buffer size remaining is smaller than the number of bytes available on the socket to be read, only the number of bytes that can be read into the buffer
are actually read. After this the application expects another handle_input for the remaining bytes that are still on the socket that are yet to be read. In this scenario, we never receive the subsequent handle_input event so that we can do the next peer().recv(buf,len)
call to read the remaining bytes from the socket. As a workaround for this, we changed the buffer allocation logic to ensure the application doesn't wait for the next handle_input if there are more bytes than the remaining buffer size. We solved this problem
with the workaround, but we encountered the issues described in 3b below.<br>
b) On running load tests with a TLS client which keeps sending https requests continuously, we found that the server randomly freezes after anywhere between 1 and 30 minutes and when we check it looks like we never received a handle_input event at the TLSServer.
There is no logic on the client that causes it to stop sending requests. So, it has to be something to do with the handle_input events not being notified to the application.<br>
4) Please note that the issues 3a and 3b are not observed while using TCPServer and TCP clients. The logic in the handle_input for both TCP and TLS is exactly the same.<br>
<br>
<br>
REPEAT BY:<br>
[What you did to get the error; include test program or session<br>
transcript if at all possible. ]<br>
<br>
SAMPLE FIX/WORKAROUND:<br>
No fix available. Looking for a solution or an explanation.<br>
<br>
<span style="font-size:10.0pt;font-family:"Arial",sans-serif"><o:p></o:p></span></p>
<div class="MsoNormal" align="center" style="text-align:center"><span style="font-size:10.0pt;font-family:"Arial",sans-serif">
<hr size="3" width="100%" align="center">
</span></div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Arial",sans-serif">This email has been scanned for email related threats and delivered safely by Mimecast.<br>
For more information please visit <a href="http://www.mimecast.com">
http://www.mimecast.com</a> <o:p></o:p></span></p>
<div class="MsoNormal" align="center" style="text-align:center"><span style="font-size:10.0pt;font-family:"Arial",sans-serif">
<hr size="3" width="100%" align="center">
</span></div>
<p class="MsoNormal"><br>
<br>
<o:p></o:p></p>
<pre>_______________________________________________<o:p></o:p></pre>
<pre>ace-bugs mailing list<o:p></o:p></pre>
<pre><a href="mailto:ace-bugs@list.isis.vanderbilt.edu">ace-bugs@list.isis.vanderbilt.edu</a><o:p></o:p></pre>
<pre><a href="http://list.isis.vanderbilt.edu/cgi-bin/mailman/listinfo/ace-bugs">http://list.isis.vanderbilt.edu/cgi-bin/mailman/listinfo/ace-bugs</a><o:p></o:p></pre>
</blockquote>
</div>
<br><br><span style="font-family:Arial; Font-size:10.0pt"> <hr width="100%"> This email has been scanned for email related threats and delivered safely by Mimecast.<br> For more information please visit <a href="http://www.mimecast.com">http://www.mimecast.com</a> <hr width="100%"> </span></body></html>