Page 1 of 1

TcpGetLastRxTime

Posted: Thu Dec 14, 2017 12:23 pm
by addonray
Hi,

The docs state that TcpGetLastRxTime shouldn't be called more than once per second. Is that on a per-fd basis, or for any fd? I have 18 clients to do Keepalives with and need to know if I can use TcpGetLastRxTime in a loop for those clients. I expect to do keepalives about every 30 seconds.

Thanks,

Ray

Re: TcpGetLastRxTime

Posted: Thu Dec 14, 2017 1:10 pm
by sulliwk06
Looking at the code, it seems like it's fine to call TcpGetLastRxTime repeatedly since it isn't waiting on anything. However the TcpSendKeepAlive call uses a critical section, so that is probably the function you don't want to call too often. It uses the same critical section as other TCP code regardless of what fd you are using, so I think that is where it will affect performance.

Re: TcpGetLastRxTime

Posted: Sat Dec 16, 2017 8:06 am
by addonray
Thank you, sulliwk06. I'll put code in there to space the outgoing keepalives at 1 or 2 second intervals to go easy on the TCP stack.

Ray

Re: TcpGetLastRxTime

Posted: Sat Dec 16, 2017 11:55 am
by addonray
If the keepalives were sent from the client (instead of being generated by the Netburner module), would TcpGetLastRXTime still record the times the remote keepalives arrived? This would be a .NET client with Dart's Sockets for .NET (MS implementation under the hood).

If this was the case, I could just check TcpGetLastRXTime for a change every expected keepalive period (plus latency) from connection time.

Thanks,

Ray

Re: TcpGetLastRxTime

Posted: Mon Dec 18, 2017 5:33 am
by sulliwk06
I would think that would work.