Agree with it, it is consistent. Seems that I have suggested the same

чт, 17 февр. 2022 г., 11:05 Pavel Tupitsyn <ptupit...@apache.org>:

> I've reviewed the code again and it does not seem right to override
> user-defined heartbeat interval with a *bigger* value,
> so now I only set it to 1/3 of idleTimeout when the user-specified value is
> not already less than that.
>
> On Wed, Feb 16, 2022 at 7:19 PM Pavel Tupitsyn <ptupit...@apache.org>
> wrote:
>
> > Ok, let's keep heartbeatInterval then.
> > I've updated the code to reflect our recent agreement, please review.
> >
> > On Tue, Feb 15, 2022 at 8:28 PM Ivan Daschinsky <ivanda...@gmail.com>
> > wrote:
> >
> >> I personally prefer heartbeatInterval
> >>
> >> вт, 15 февр. 2022 г., 18:25 Pavel Tupitsyn <ptupit...@apache.org>:
> >>
> >> > > What about "keepAlive", "keepAliveInterval" then? It looks more
> common
> >> > and matches the IEP title :)
> >> > According to Google, HeartbeatInterval has ~169K results, and
> >> > KeepAliveInterval has ~110K :)
> >> >
> >> > In my experience, both are well understood. I am equally willing to
> use
> >> any
> >> > of them.
> >> > Any other opinions?
> >> >
> >> > On Tue, Feb 15, 2022 at 6:11 PM Maksim Timonin <
> timoninma...@apache.org
> >> >
> >> > wrote:
> >> >
> >> > > What about "keepAlive", "keepAliveInterval" then? It looks more
> common
> >> > and
> >> > > matches the IEP title :)
> >> > >
> >> > > On Tue, Feb 15, 2022 at 5:54 PM Pavel Tupitsyn <
> ptupit...@apache.org>
> >> > > wrote:
> >> > >
> >> > > > To summarize, we add two properties to the ClientConfiguration:
> >> > > > bool heartbeatsEnabled = true;
> >> > > > long defaultHeartbeatInterval = 60_000; // Default 1 minute, used
> >> > > >
> >> > > > Logic:
> >> > > > if (heartbeatsEnabled) {
> >> > > >   heartbeatInterval = serverIdleTimeout > 0 ? serverIdleTimeout /
> 3
> >> :
> >> > > > defaultHeartbeatInterval;
> >> > > > }
> >> > > >
> >> > > >
> >> > > > Thoughts, objections?
> >> > > >
> >> > > > On Tue, Feb 15, 2022 at 4:32 PM Ivan Daschinsky <
> >> ivanda...@gmail.com>
> >> > > > wrote:
> >> > > >
> >> > > > > Pavel, sorry, i've made mistake. But current behaviour is ok for
> >> me.
> >> > > This
> >> > > > > timeout cannot be change on server side runtime. But we can
> >> simplify
> >> > > > > protocol just use one opcode and message
> >> > > > >
> >> > > > > вт, 15 февр. 2022 г., 14:54 Ivan Daschinsky <
> ivanda...@gmail.com
> >> >:
> >> > > > >
> >> > > > > > > Idle timeout can't change, why send it back with every
> >> heartbeat
> >> > > > > > response?
> >> > > > > > May be I am wrong, but from code I see this behaviour. But if
> I
> >> am
> >> > > > wrong,
> >> > > > > > this is ok behaviour for me.
> >> > > > > >
> >> > > > > >
> >> > > > > >
> >> > > > > > вт, 15 февр. 2022 г. в 14:00, Pavel Tupitsyn <
> >> ptupit...@apache.org
> >> > >:
> >> > > > > >
> >> > > > > >> Ivan, I mostly agree with your proposal, except this point:
> >> > > > > >>
> >> > > > > >> > Response to heartbeat request -- is idle timeout
> >> > > > > >> Idle timeout can't change, why send it back with every
> >> heartbeat
> >> > > > > response?
> >> > > > > >>
> >> > > > > >> > possible cases with cluster restart, upgrade
> >> > > > > >> In those cases, a new connection will be established, and
> we'll
> >> > > > retrieve
> >> > > > > >> the new timeout after the handshake.
> >> > > > > >>
> >> > > > > >>
> >> > > > > >> On Tue, Feb 15, 2022 at 12:04 PM Maksim Timonin <
> >> > > > > timoninma...@apache.org>
> >> > > > > >> wrote:
> >> > > > > >>
> >> > > > > >> > Hi Ivan,
> >> > > > > >> >
> >> > > > > >> > Cases you described sound reasonable to me. Then the client
> >> > should
> >> > > > > just
> >> > > > > >> set
> >> > > > > >> > up the `keepAlive` flag, and it just works.
> >> > > > > >> >
> >> > > > > >> > So, there are 3 branches:
> >> > > > > >> > 1. Users don't configure keepAlive at all.
> >> > > > > >> > 2. Users configure keepAliveHeartbeatInterval (long, ms).
> >> > > > > >> > 3. Users configure keepAlive (boolean).
> >> > > > > >> >
> >> > > > > >> > AFAIU, Pavel's proposal is about covering the second case
> >> only.
> >> > > But
> >> > > > > >> > actually the 2nd and 3rd aren't conflicted with each
> other.I
> >> > think
> >> > > > for
> >> > > > > >> both
> >> > > > > >> > branches, a cluster should respond with idleTimeout value
> on
> >> > every
> >> > > > > keep
> >> > > > > >> > alive client request. Because there are possible cases with
> >> > > cluster
> >> > > > > >> > restart, upgrade, etc. Clients should check every response
> >> and
> >> > in
> >> > > > case
> >> > > > > >> of
> >> > > > > >> > changed idleTimeout. For 2nd case write a WARN message, and
> >> for
> >> > > 3rd
> >> > > > -
> >> > > > > >> > reconfigure themself in case of changed idleTimeout.
> >> > > > > >> >
> >> > > > > >> >
> >> > > > > >> >
> >> > > > > >> >
> >> > > > > >> > On Tue, Feb 15, 2022 at 9:51 AM Ivan Daschinsky <
> >> > > > ivanda...@gmail.com>
> >> > > > > >> > wrote:
> >> > > > > >> >
> >> > > > > >> > > Regarding discussion here [1]
> >> > > > > >> > >
> >> > > > > >> > > I suppose that this feature, despite the fact that
> initial
> >> > > > intention
> >> > > > > >> of
> >> > > > > >> > > Pavel was different, can drastically
> >> > > > > >> > > improve the usage pattern of thin clients and give a lot
> of
> >> > > > > >> opportunities
> >> > > > > >> > > if the following is done:
> >> > > > > >> > >
> >> > > > > >> > > 1. GridNioServer has a great feature -- idle timeout.
> If  a
> >> > > server
> >> > > > > did
> >> > > > > >> > not
> >> > > > > >> > > receive any from a client -- it will be kicked off.
> >> > > > > >> > >     But there are some scenarios that make the use of
> this
> >> > > feature
> >> > > > > >> > > impossible:
> >> > > > > >> > > a. Multiple workers waiting for batch tasks and
> relatively
> >> low
> >> > > > > >> requests
> >> > > > > >> > > rate -- this services will be often kicked off and must
> >> > > reconnect.
> >> > > > > >> > > In order to prevent this behaviour, the user must
> >> implement a
> >> > > kind
> >> > > > > of
> >> > > > > >> > > heartbeating by himself.
> >> > > > > >> > > b. Quite often user may want to implement leader-follower
> >> > > pattern
> >> > > > > for
> >> > > > > >> > > services for HA, so followers also will be considered as
> >> idle.
> >> > > > > Kicking
> >> > > > > >> > off
> >> > > > > >> > > these followers
> >> > > > > >> > > is not acceptable, so user  should also implement
> >> heartbeating
> >> > > by
> >> > > > > >> > himself.
> >> > > > > >> > >
> >> > > > > >> > > My proposition is:
> >> > > > > >> > > 1. Add two flags -- enable/disable heartbeats, and very
> >> > optional
> >> > > > > >> > heartbeat
> >> > > > > >> > > timeout. Set enable to true by default, timeout to
> default
> >> > > > heartbeat
> >> > > > > >> > > timeout.
> >> > > > > >> > > 2. If server and client both support this feature, and
> >> > > heartbeats
> >> > > > > are
> >> > > > > >> not
> >> > > > > >> > > explicitly disabled on client side:
> >> > > > > >> > > 3. Response to heartbeat request -- is idle timeout. If
> >> idle
> >> > > > timeout
> >> > > > > >> is
> >> > > > > >> > set
> >> > > > > >> > > on the server side , set heartbeat timeout to one-third
> of
> >> it,
> >> > > > > instead
> >> > > > > >> > set
> >> > > > > >> > > to default or specified value.
> >> > > > > >> > >
> >> > > > > >> > > Pros:
> >> > > > > >> > > 1. Easy to set up -- just flag on client side and just
> set
> >> > > timeout
> >> > > > > on
> >> > > > > >> > > server side.
> >> > > > > >> > > 2. Hard to configure improperly, i.e set heartbeat
> timeout
> >> not
> >> > > > short
> >> > > > > >> > enough
> >> > > > > >> > > in order to prevent kicking out by server.
> >> > > > > >> > > 3. If the user just wants heartbeats without setting idle
> >> > > timeout
> >> > > > --
> >> > > > > >> > > heartbeats are by default on and with reasonable timeout.
> >> > > > > >> > >
> >> > > > > >> > > Cons:
> >> > > > > >> > > 1. If someone will rely on old behavior and just wants to
> >> drop
> >> > > his
> >> > > > > >> > clients
> >> > > > > >> > > on timeout -- this will not work without reconfiguring,
> he
> >> > > should
> >> > > > > >> disable
> >> > > > > >> > > heartbeats.
> >> > > > > >> > > But I cannot even imagine that someone will find this
> >> > behaviour
> >> > > > > >> > desirable.
> >> > > > > >> > > I strongly believe that this behaviour prevents users
> from
> >> > using
> >> > > > > >> > > idleTimeout on server side.
> >> > > > > >> > >
> >> > > > > >> > > [1] --
> >> > > > > >>
> >> https://github.com/apache/ignite/pull/9817#discussion_r805628955
> >> > > > > >> > >
> >> > > > > >> > > пт, 11 февр. 2022 г. в 10:58, Pavel Tupitsyn <
> >> > > > ptupit...@apache.org
> >> > > > > >:
> >> > > > > >> > >
> >> > > > > >> > > > I've prepared a PR, please have a look:
> >> > > > > >> > > > https://github.com/apache/ignite/pull/9817
> >> > > > > >> > > >
> >> > > > > >> > > > On Mon, Feb 7, 2022 at 6:37 PM Ivan Daschinsky <
> >> > > > > ivanda...@gmail.com
> >> > > > > >> >
> >> > > > > >> > > > wrote:
> >> > > > > >> > > >
> >> > > > > >> > > > > I see potential in this feature, especially if we use
> >> > > > something
> >> > > > > >> like
> >> > > > > >> > > > > continuous query. Stale clients can consume a lot of
> >> > > resources
> >> > > > > >> and it
> >> > > > > >> > > is
> >> > > > > >> > > > > worth kick these clients out.
> >> > > > > >> > > > >
> >> > > > > >> > > > > пн, 7 февр. 2022 г. в 18:25, Pavel Tupitsyn <
> >> > > > > ptupit...@apache.org
> >> > > > > >> >:
> >> > > > > >> > > > >
> >> > > > > >> > > > > > > If we use new approach, we can reduce this
> timeout.
> >> > But
> >> > > > this
> >> > > > > >> can
> >> > > > > >> > > > affect
> >> > > > > >> > > > > > old clients.
> >> > > > > >> > > > > >
> >> > > > > >> > > > > > idleTimeout is disabled by default, we are not
> going
> >> to
> >> > > > change
> >> > > > > >> > this.
> >> > > > > >> > > > > >
> >> > > > > >> > > > > > > Also, let's think about that sending heartbeats
> and
> >> > > > interval
> >> > > > > >> of
> >> > > > > >> > > > sending
> >> > > > > >> > > > > > > heartbeats could be calculated on the server side
> >> > (i.e.
> >> > > > one
> >> > > > > >> third
> >> > > > > >> > > of
> >> > > > > >> > > > > idle
> >> > > > > >> > > > > > > timeout) and sent to the client during handshake.
> >> > > > > >> > > > > > > Also we can introduce something like a
> negotiation
> >> > > > mechanism
> >> > > > > >> as
> >> > > > > >> > in
> >> > > > > >> > > > > > > zookeeper.
> >> > > > > >> > > > > >
> >> > > > > >> > > > > > I tend to agree with Maksim here, let's keep it
> >> simple
> >> > and
> >> > > > > >> > explicit.
> >> > > > > >> > > > > > Log a warning, but don't do anything clever.
> >> > > > > >> > > > > >
> >> > > > > >> > > > > > On Mon, Feb 7, 2022 at 6:15 PM Ivan Daschinsky <
> >> > > > > >> > ivanda...@gmail.com>
> >> > > > > >> > > > > > wrote:
> >> > > > > >> > > > > >
> >> > > > > >> > > > > > > >> idleTimeout already exists, I don't think we
> >> should
> >> > > > > change
> >> > > > > >> the
> >> > > > > >> > > way
> >> > > > > >> > > > > it
> >> > > > > >> > > > > > > works (or did I misunderstand you?)
> >> > > > > >> > > > > > > If we use new approach, we can reduce this
> timeout.
> >> > But
> >> > > > this
> >> > > > > >> can
> >> > > > > >> > > > affect
> >> > > > > >> > > > > > old
> >> > > > > >> > > > > > > clients.
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > > > Also, let's think about that sending heartbeats
> and
> >> > > > interval
> >> > > > > >> of
> >> > > > > >> > > > sending
> >> > > > > >> > > > > > > heartbeats could be calculated on the server side
> >> > (i.e.
> >> > > > one
> >> > > > > >> third
> >> > > > > >> > > of
> >> > > > > >> > > > > idle
> >> > > > > >> > > > > > > timeout) and sent to the client
> >> > > > > >> > > > > > > during handshake.
> >> > > > > >> > > > > > > Also we can introduce something like a
> negotiation
> >> > > > mechanism
> >> > > > > >> as
> >> > > > > >> > in
> >> > > > > >> > > > > > > zookeeper.
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > > > пн, 7 февр. 2022 г. в 18:05, Pavel Tupitsyn <
> >> > > > > >> > ptupit...@apache.org
> >> > > > > >> > > >:
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > > > > Igor,
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > Maybe clients should pass this information on
> >> to
> >> > the
> >> > > > > >> > handshake.
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > Do you think we should log a mismatched timeout
> >> > > warning
> >> > > > on
> >> > > > > >> the
> >> > > > > >> > > > > server,
> >> > > > > >> > > > > > > not
> >> > > > > >> > > > > > > > on the client?
> >> > > > > >> > > > > > > > Or should we do both?
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > I've updated the proposal with
> >> OP_GET_IDLE_TIMEOUT
> >> > and
> >> > > > > some
> >> > > > > >> > other
> >> > > > > >> > > > > > details
> >> > > > > >> > > > > > > > discussed above.
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > On Mon, Feb 7, 2022 at 5:42 PM Igor Sapego <
> >> > > > > >> isap...@apache.org
> >> > > > > >> > >
> >> > > > > >> > > > > wrote:
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > Feature seems useful for me as it makes
> >> connection
> >> > > > > >> management
> >> > > > > >> > > > more
> >> > > > > >> > > > > > > robust
> >> > > > > >> > > > > > > > > and
> >> > > > > >> > > > > > > > > predictable.
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > I agree with Pavel, that we should print
> >> warning
> >> > > when
> >> > > > > >> > heartbeat
> >> > > > > >> > > > > > period
> >> > > > > >> > > > > > > is
> >> > > > > >> > > > > > > > > larger than
> >> > > > > >> > > > > > > > > idle timeout, but I see a problem here as
> idle
> >> > > timeout
> >> > > > > is
> >> > > > > >> > > > > configured
> >> > > > > >> > > > > > on
> >> > > > > >> > > > > > > > > server and is not
> >> > > > > >> > > > > > > > > known to clients, while heartbeats configured
> >> on
> >> > > > clients
> >> > > > > >> and
> >> > > > > >> > > > their
> >> > > > > >> > > > > > > period
> >> > > > > >> > > > > > > > > is not known
> >> > > > > >> > > > > > > > > to the server. Maybe clients should pass this
> >> > > > > information
> >> > > > > >> on
> >> > > > > >> > to
> >> > > > > >> > > > the
> >> > > > > >> > > > > > > > > handshake.
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > Regarding Python and PHP clients - can not we
> >> use
> >> > > some
> >> > > > > >> kind
> >> > > > > >> > of
> >> > > > > >> > > > > timers
> >> > > > > >> > > > > > > to
> >> > > > > >> > > > > > > > > implement
> >> > > > > >> > > > > > > > > this feature?
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > Best Regards,
> >> > > > > >> > > > > > > > > Igor
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > On Mon, Feb 7, 2022 at 5:23 PM Pavel
> Tupitsyn <
> >> > > > > >> > > > > ptupit...@apache.org>
> >> > > > > >> > > > > > > > > wrote:
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > Maksim, agree. Let's not be too clever and
> >> only
> >> > > log
> >> > > > a
> >> > > > > >> > > warning.
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > On Mon, Feb 7, 2022 at 5:23 PM Pavel
> >> Tupitsyn <
> >> > > > > >> > > > > > ptupit...@apache.org>
> >> > > > > >> > > > > > > > > > wrote:
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > > Ivan, idleTimeout already exists, I don't
> >> > think
> >> > > we
> >> > > > > >> should
> >> > > > > >> > > > > change
> >> > > > > >> > > > > > > the
> >> > > > > >> > > > > > > > > way
> >> > > > > >> > > > > > > > > > > it works (or did I misunderstand you?)
> >> > > > > >> > > > > > > > > > >
> >> > > > > >> > > > > > > > > > > Of course, enabling heartbeats means that
> >> > > > otherwise
> >> > > > > >> idle
> >> > > > > >> > > > > clients
> >> > > > > >> > > > > > > will
> >> > > > > >> > > > > > > > > no
> >> > > > > >> > > > > > > > > > > longer be disconnected by the server.
> >> > > > > >> > > > > > > > > > > I think we should cross-link those
> >> properties
> >> > in
> >> > > > the
> >> > > > > >> > > > > > documentation
> >> > > > > >> > > > > > > > and
> >> > > > > >> > > > > > > > > > > explain this behavior.
> >> > > > > >> > > > > > > > > > >
> >> > > > > >> > > > > > > > > > > On Mon, Feb 7, 2022 at 4:39 PM Ivan
> >> > Daschinsky <
> >> > > > > >> > > > > > > ivanda...@gmail.com>
> >> > > > > >> > > > > > > > > > > wrote:
> >> > > > > >> > > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> >>3. Already implemented: when
> >> > > > > >> > > > > > > > > ClientConnectorConfiguration#idleTimeout
> >> > > > > >> > > > > > > > > > is
> >> > > > > >> > > > > > > > > > >> not zero, server disconnects idle
> clients
> >> > > > > >> > > > > > > > > > >> >>
> >> > > > > >> > > > > > > > > > >> But I suppose it would be great to have:
> >> > > > > >> > > > > > > > > > >> 1. If client supports keep alive, use
> >> > > idleTimeout
> >> > > > > >> > > > > > > > > > >> 2. If not, do not use it.
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> But I am not sure if it is correct or
> not.
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> пн, 7 февр. 2022 г. в 16:01, Maksim
> >> Timonin <
> >> > > > > >> > > > > > > > timoninma...@apache.org
> >> > > > > >> > > > > > > > > >:
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > I believe explicit is better than
> >> implicit
> >> > :)
> >> > > > > Also
> >> > > > > >> in
> >> > > > > >> > > case
> >> > > > > >> > > > > of
> >> > > > > >> > > > > > > > > dynamic
> >> > > > > >> > > > > > > > > > >> > calculation of timeout, it can change
> >> > > > > dynamically,
> >> > > > > >> for
> >> > > > > >> > > > > example
> >> > > > > >> > > > > > > > > > >> restarting a
> >> > > > > >> > > > > > > > > > >> > cluster with different configuration
> >> should
> >> > > > > >> > reconfigure
> >> > > > > >> > > > > > clients
> >> > > > > >> > > > > > > > too.
> >> > > > > >> > > > > > > > > > >> Looks
> >> > > > > >> > > > > > > > > > >> > complicated.
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >> > My vote for WARN + javadocs with
> >> mention of
> >> > > > this
> >> > > > > >> > issue.
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >> > On Mon, Feb 7, 2022 at 3:51 PM Pavel
> >> > > Tupitsyn <
> >> > > > > >> > > > > > > > ptupit...@apache.org
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > wrote:
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >> > > > WDYT, should we add a WARN message
> >> for
> >> > > > > clients
> >> > > > > >> > that
> >> > > > > >> > > > > > > configure
> >> > > > > >> > > > > > > > > > >> > > > keepAliveTimeout greater than
> >> > idleTimeout
> >> > > > on
> >> > > > > >> the
> >> > > > > >> > > > server
> >> > > > > >> > > > > > > side?
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> > > I think we should either log a WARN,
> >> or
> >> > > > > retrieve
> >> > > > > >> > > > > idleTimeout
> >> > > > > >> > > > > > > > from
> >> > > > > >> > > > > > > > > > >> server
> >> > > > > >> > > > > > > > > > >> > > and configure heartbeatTimeout
> >> > accordingly
> >> > > > > (e.g.
> >> > > > > >> > > divide
> >> > > > > >> > > > by
> >> > > > > >> > > > > > 2).
> >> > > > > >> > > > > > > > > > >> > > Thoughts?
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> > > On Mon, Feb 7, 2022 at 3:14 PM
> Maksim
> >> > > > Timonin <
> >> > > > > >> > > > > > > > > > >> timoninma...@apache.org>
> >> > > > > >> > > > > > > > > > >> > > wrote:
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> > > > Hi Pavel,
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > > Thanks for the links. Yes, I
> forgot
> >> > that
> >> > > > the
> >> > > > > >> flag
> >> > > > > >> > of
> >> > > > > >> > > > > > changed
> >> > > > > >> > > > > > > > > > >> topology
> >> > > > > >> > > > > > > > > > >> > is
> >> > > > > >> > > > > > > > > > >> > > > lazy. Also I missed that the
> >> keepAlive
> >> > > > > setting
> >> > > > > >> is
> >> > > > > >> > > > > > configured
> >> > > > > >> > > > > > > > on
> >> > > > > >> > > > > > > > > > the
> >> > > > > >> > > > > > > > > > >> > > client
> >> > > > > >> > > > > > > > > > >> > > > side (alternatively to idleTimeout
> >> that
> >> > > is
> >> > > > on
> >> > > > > >> the
> >> > > > > >> > > > server
> >> > > > > >> > > > > > > > side).
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > > Now I understand, this feature can
> >> be
> >> > > > helpful
> >> > > > > >> > then.
> >> > > > > >> > > > > Every
> >> > > > > >> > > > > > > > client
> >> > > > > >> > > > > > > > > > can
> >> > > > > >> > > > > > > > > > >> > > > configure itself in case it's
> >> possible
> >> > to
> >> > > > be
> >> > > > > >> idle
> >> > > > > >> > > > > > sometimes,
> >> > > > > >> > > > > > > > and
> >> > > > > >> > > > > > > > > > >> choose
> >> > > > > >> > > > > > > > > > >> > > > an appropriate timeout by itself
> >> too.
> >> > And
> >> > > > by
> >> > > > > >> > default
> >> > > > > >> > > > the
> >> > > > > >> > > > > > > > feature
> >> > > > > >> > > > > > > > > > >> should
> >> > > > > >> > > > > > > > > > >> > > be
> >> > > > > >> > > > > > > > > > >> > > > disabled.
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > > WDYT, should we add a WARN message
> >> for
> >> > > > > clients
> >> > > > > >> > that
> >> > > > > >> > > > > > > configure
> >> > > > > >> > > > > > > > > > >> > > > keepAliveTimeout greater than
> >> > idleTimeout
> >> > > > on
> >> > > > > >> the
> >> > > > > >> > > > server
> >> > > > > >> > > > > > > side?
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > > On Mon, Feb 7, 2022 at 1:05 PM
> Pavel
> >> > > > > Tupitsyn <
> >> > > > > >> > > > > > > > > > ptupit...@apache.org
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >> > > > wrote:
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > > > > Ivan,
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > I suggest the following:
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > 1. Server sends KEEP_ALIVE
> feature
> >> > > flag,
> >> > > > > >> which
> >> > > > > >> > > means
> >> > > > > >> > > > > it
> >> > > > > >> > > > > > > > > accepts
> >> > > > > >> > > > > > > > > > >> > > > > OP_KEEP_ALIVE empty message
> >> > > > > >> > > > > > > > > > >> > > > > 2. Client sends OP_KEEP_ALIVE
> when
> >> > the
> >> > > > > >> > connection
> >> > > > > >> > > is
> >> > > > > >> > > > > > idle
> >> > > > > >> > > > > > > > for
> >> > > > > >> > > > > > > > > a
> >> > > > > >> > > > > > > > > > >> > > > > certain period of time
> >> > > > > >> > > > > > > > > > >> > > > > 3. Already implemented: when
> >> > > > > >> > > > > > > > > > >> ClientConnectorConfiguration#idleTimeout
> >> > > > > >> > > > > > > > > > >> > > is
> >> > > > > >> > > > > > > > > > >> > > > > not zero, server disconnects
> idle
> >> > > clients
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > This way we don't need
> >> server->client
> >> > > > > >> > keepalives,
> >> > > > > >> > > as
> >> > > > > >> > > > > you
> >> > > > > >> > > > > > > > > > correctly
> >> > > > > >> > > > > > > > > > >> > > noted.
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > On Mon, Feb 7, 2022 at 12:43 PM
> >> Ivan
> >> > > > > >> Daschinsky
> >> > > > > >> > <
> >> > > > > >> > > > > > > > > > >> ivanda...@gmail.com
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> > > > > wrote:
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > Pavel, I suppose that ideally:
> >> > > > > >> > > > > > > > > > >> > > > > > 1. Client send in handshake
> >> flag,
> >> > > that
> >> > > > it
> >> > > > > >> > > supports
> >> > > > > >> > > > > > > > > KEEP_ALIVE
> >> > > > > >> > > > > > > > > > >> > feature
> >> > > > > >> > > > > > > > > > >> > > > and
> >> > > > > >> > > > > > > > > > >> > > > > > server takes it into account.
> >> > > > > >> > > > > > > > > > >> > > > > > 2. Each request of client can
> be
> >> > > > > >> considered as
> >> > > > > >> > > > > > > keep-alive
> >> > > > > >> > > > > > > > > > ping.
> >> > > > > >> > > > > > > > > > >> > > > > > 3. Client send failure should
> be
> >> > > > > processed
> >> > > > > >> > using
> >> > > > > >> > > > > retry
> >> > > > > >> > > > > > > > > policy.
> >> > > > > >> > > > > > > > > > >> > > > > > 4. Server should not send
> >> > keep-alive
> >> > > > > >> packets,
> >> > > > > >> > it
> >> > > > > >> > > > is
> >> > > > > >> > > > > > > > > redundant,
> >> > > > > >> > > > > > > > > > >> but
> >> > > > > >> > > > > > > > > > >> > > > server
> >> > > > > >> > > > > > > > > > >> > > > > > should track requests from
> >> client
> >> > and
> >> > > > if
> >> > > > > >> there
> >> > > > > >> > > is
> >> > > > > >> > > > no
> >> > > > > >> > > > > > > > > requests
> >> > > > > >> > > > > > > > > > >> from
> >> > > > > >> > > > > > > > > > >> > > > client
> >> > > > > >> > > > > > > > > > >> > > > > > with KEEP_ALIVE feature,
> >> > > > > >> > > > > > > > > > >> > > > > > automatically close connection
> >> and
> >> > > free
> >> > > > > >> > > resources.
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > Similar approach is used in
> >> > zookeeper
> >> > > > > >> clients.
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > пн, 7 февр. 2022 г. в 12:24,
> >> Pavel
> >> > > > > >> Tupitsyn <
> >> > > > > >> > > > > > > > > > >> ptupit...@apache.org
> >> > > > > >> > > > > > > > > > >> > >:
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > Ivan,
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > Ideally, the check should
> come
> >> > from
> >> > > > > both
> >> > > > > >> > > sides.
> >> > > > > >> > > > > > > > > > >> > > > > > > - Client periodically sends
> >> > > keepalive
> >> > > > > to
> >> > > > > >> > > server
> >> > > > > >> > > > > > > > > > >> > > > > > > - Server periodically sends
> >> > > keepalive
> >> > > > > to
> >> > > > > >> > > client
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > Feature flags will be added
> >> > > > > accordingly,
> >> > > > > >> so
> >> > > > > >> > it
> >> > > > > >> > > > is
> >> > > > > >> > > > > > not
> >> > > > > >> > > > > > > > > > >> necessary
> >> > > > > >> > > > > > > > > > >> > to
> >> > > > > >> > > > > > > > > > >> > > > > > > implement this in all thin
> >> > clients.
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > On Mon, Feb 7, 2022 at 11:43
> >> AM
> >> > > Ivan
> >> > > > > >> > > Daschinsky
> >> > > > > >> > > > <
> >> > > > > >> > > > > > > > > > >> > > ivanda...@gmail.com
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > wrote:
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > I suppose it is great
> idea,
> >> but
> >> > > > this
> >> > > > > >> > > > > functionality
> >> > > > > >> > > > > > > can
> >> > > > > >> > > > > > > > > be
> >> > > > > >> > > > > > > > > > >> hard
> >> > > > > >> > > > > > > > > > >> > to
> >> > > > > >> > > > > > > > > > >> > > > > > > implement
> >> > > > > >> > > > > > > > > > >> > > > > > > > for some platforms. I.e.
> >> sync
> >> > > > python
> >> > > > > >> > client
> >> > > > > >> > > or
> >> > > > > >> > > > > php
> >> > > > > >> > > > > > > > > (there
> >> > > > > >> > > > > > > > > > >> is no
> >> > > > > >> > > > > > > > > > >> > > > real
> >> > > > > >> > > > > > > > > > >> > > > > > > > multithreading for python
> >> (GIL)
> >> > > and
> >> > > > > >> php is
> >> > > > > >> > > > > single
> >> > > > > >> > > > > > > > > threaded
> >> > > > > >> > > > > > > > > > >> by
> >> > > > > >> > > > > > > > > > >> > > > > design).
> >> > > > > >> > > > > > > > > > >> > > > > > > But
> >> > > > > >> > > > > > > > > > >> > > > > > > > for async clients it is
> not
> >> > very
> >> > > > hard
> >> > > > > >> to
> >> > > > > >> > > > > > implement.
> >> > > > > >> > > > > > > > > > >> > Nevertheless,
> >> > > > > >> > > > > > > > > > >> > > > > this
> >> > > > > >> > > > > > > > > > >> > > > > > > > feature should be
> optional,
> >> > > because
> >> > > > > of
> >> > > > > >> > > > possible
> >> > > > > >> > > > > > > > > technical
> >> > > > > >> > > > > > > > > > >> > > > > limitations.
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > Pavel, is this check
> mostly
> >> for
> >> > > > > client
> >> > > > > >> > side?
> >> > > > > >> > > > Or
> >> > > > > >> > > > > > > > servers
> >> > > > > >> > > > > > > > > > can
> >> > > > > >> > > > > > > > > > >> do
> >> > > > > >> > > > > > > > > > >> > > some
> >> > > > > >> > > > > > > > > > >> > > > > > > actions
> >> > > > > >> > > > > > > > > > >> > > > > > > > if there is no activity
> from
> >> > thin
> >> > > > > >> client
> >> > > > > >> > > (i.e.
> >> > > > > >> > > > > > > closing
> >> > > > > >> > > > > > > > > > >> context
> >> > > > > >> > > > > > > > > > >> > > and
> >> > > > > >> > > > > > > > > > >> > > > > free
> >> > > > > >> > > > > > > > > > >> > > > > > > > resources such as queries'
> >> > > handles
> >> > > > > and
> >> > > > > >> so
> >> > > > > >> > > on?)
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > пн, 7 февр. 2022 г. в
> 11:09,
> >> > > Pavel
> >> > > > > >> > Tupitsyn
> >> > > > > >> > > <
> >> > > > > >> > > > > > > > > > >> > > ptupit...@apache.org
> >> > > > > >> > > > > > > > > > >> > > > >:
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > Hi Maksim,
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > half-state is a
> possible
> >> > > > > situation
> >> > > > > >> > when
> >> > > > > >> > > an
> >> > > > > >> > > > > > > Ignite
> >> > > > > >> > > > > > > > > node
> >> > > > > >> > > > > > > > > > >> goes
> >> > > > > >> > > > > > > > > > >> > > > down
> >> > > > > >> > > > > > > > > > >> > > > > or
> >> > > > > >> > > > > > > > > > >> > > > > > > > > somehow removes
> connection
> >> > to a
> >> > > > > thin
> >> > > > > >> > > client
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > Half-open state is also
> >> > > possible
> >> > > > > >> when,
> >> > > > > >> > for
> >> > > > > >> > > > > > > example,
> >> > > > > >> > > > > > > > an
> >> > > > > >> > > > > > > > > > >> > > > intermediate
> >> > > > > >> > > > > > > > > > >> > > > > > > > router
> >> > > > > >> > > > > > > > > > >> > > > > > > > > is rebooted [1].
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > This is what we seem to
> >> have
> >> > > > > >> encountered
> >> > > > > >> > > > with
> >> > > > > >> > > > > > one
> >> > > > > >> > > > > > > of
> >> > > > > >> > > > > > > > > our
> >> > > > > >> > > > > > > > > > >> > > > customers
> >> > > > > >> > > > > > > > > > >> > > > > -
> >> > > > > >> > > > > > > > > > >> > > > > > > they
> >> > > > > >> > > > > > > > > > >> > > > > > > > > have a stable cluster,
> and
> >> > > > > >> long-living
> >> > > > > >> > > > > (multiple
> >> > > > > >> > > > > > > > days)
> >> > > > > >> > > > > > > > > > >> thin
> >> > > > > >> > > > > > > > > > >> > > > client
> >> > > > > >> > > > > > > > > > >> > > > > > > > > connections which can be
> >> idle
> >> > > for
> >> > > > > >> some
> >> > > > > >> > > time.
> >> > > > > >> > > > > > > > > > >> > > > > > > > > And only when we send
> some
> >> > data
> >> > > > on
> >> > > > > >> such
> >> > > > > >> > an
> >> > > > > >> > > > > idle
> >> > > > > >> > > > > > > > > > >> connection do
> >> > > > > >> > > > > > > > > > >> > > we
> >> > > > > >> > > > > > > > > > >> > > > > > > discover
> >> > > > > >> > > > > > > > > > >> > > > > > > > > that it is broken.
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > But with enabled (true
> >> by
> >> > > > > default)
> >> > > > > >> > > > > > > > > partitionAwareness
> >> > > > > >> > > > > > > > > > >> > feature
> >> > > > > >> > > > > > > > > > >> > > > > > clients
> >> > > > > >> > > > > > > > > > >> > > > > > > > can
> >> > > > > >> > > > > > > > > > >> > > > > > > > > be notified about
> topology
> >> > > > changes
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > Partition awareness is a
> >> > "lazy"
> >> > > > > >> > > notification
> >> > > > > >> > > > > in
> >> > > > > >> > > > > > a
> >> > > > > >> > > > > > > > form
> >> > > > > >> > > > > > > > > > of
> >> > > > > >> > > > > > > > > > >> a
> >> > > > > >> > > > > > > > > > >> > > > > response
> >> > > > > >> > > > > > > > > > >> > > > > > > > > message flag [2].
> >> > > > > >> > > > > > > > > > >> > > > > > > > > You won't get one on an
> >> idle
> >> > > > > >> connection.
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > the connections are
> >> removed
> >> > > on
> >> > > > > the
> >> > > > > >> > > server
> >> > > > > >> > > > > side
> >> > > > > >> > > > > > > by
> >> > > > > >> > > > > > > > > > client
> >> > > > > >> > > > > > > > > > >> > idle
> >> > > > > >> > > > > > > > > > >> > > > > > timeout
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > Idle timeout is disabled
> >> by
> >> > > > > default.
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > is it OK to keep such
> >> > > > connections
> >> > > > > >> > alive
> >> > > > > >> > > > for
> >> > > > > >> > > > > a
> >> > > > > >> > > > > > > long
> >> > > > > >> > > > > > > > > > time
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > I think it is up to the
> >> user.
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > in the case of
> partition
> >> > > > > awareness
> >> > > > > >> > > > features
> >> > > > > >> > > > > it
> >> > > > > >> > > > > > > can
> >> > > > > >> > > > > > > > > > lead
> >> > > > > >> > > > > > > > > > >> to
> >> > > > > >> > > > > > > > > > >> > > > > wasting
> >> > > > > >> > > > > > > > > > >> > > > > > > TCP
> >> > > > > >> > > > > > > > > > >> > > > > > > > > sockets on Ignite nodes,
> >> > can't
> >> > > it
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > Can you please
> elaborate?
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > [1]
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > >
> >> > > > > >> > > > >
> >> > > > > >> > > >
> >> > > > > >> > >
> >> > > > > >> >
> >> > > > > >>
> >> > > > >
> >> > > >
> >> > >
> >> >
> >>
> https://blog.stephencleary.com/2009/05/detection-of-half-open-dropped.html
> >> > > > > >> > > > > > > > > > >> > > > > > > > > [2]
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > >
> >> > > > > >> > > > >
> >> > > > > >> > > >
> >> > > > > >> > >
> >> > > > > >> >
> >> > > > > >>
> >> > > > >
> >> > > >
> >> > >
> >> >
> >>
> https://cwiki.apache.org/confluence/display/IGNITE/IEP-23%3A+Best+Effort+Affinity+for+Thin+Clients
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > On Fri, Feb 4, 2022 at
> >> 4:01
> >> > PM
> >> > > > > Maksim
> >> > > > > >> > > > Timonin
> >> > > > > >> > > > > <
> >> > > > > >> > > > > > > > > > >> > > > > > timoninma...@apache.org
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > wrote:
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > Hi Pavel,
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > Thanks for starting
> this
> >> > > > thread!
> >> > > > > >> Can I
> >> > > > > >> > > ask
> >> > > > > >> > > > > > some
> >> > > > > >> > > > > > > > > > >> questions
> >> > > > > >> > > > > > > > > > >> > > here
> >> > > > > >> > > > > > > > > > >> > > > to
> >> > > > > >> > > > > > > > > > >> > > > > > get
> >> > > > > >> > > > > > > > > > >> > > > > > > > the
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > feature more clearly?
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > As I understand it
> >> > correctly,
> >> > > > > >> > half-state
> >> > > > > >> > > > is
> >> > > > > >> > > > > a
> >> > > > > >> > > > > > > > > possible
> >> > > > > >> > > > > > > > > > >> > > > situation
> >> > > > > >> > > > > > > > > > >> > > > > > when
> >> > > > > >> > > > > > > > > > >> > > > > > > > an
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > Ignite node goes down
> or
> >> > > > somehow
> >> > > > > >> > removes
> >> > > > > >> > > > > > > > connection
> >> > > > > >> > > > > > > > > > to a
> >> > > > > >> > > > > > > > > > >> > thin
> >> > > > > >> > > > > > > > > > >> > > > > > client.
> >> > > > > >> > > > > > > > > > >> > > > > > > > But
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > with enabled (true by
> >> > > default)
> >> > > > > >> > > > > > > partitionAwareness
> >> > > > > >> > > > > > > > > > >> feature
> >> > > > > >> > > > > > > > > > >> > > > clients
> >> > > > > >> > > > > > > > > > >> > > > > > can
> >> > > > > >> > > > > > > > > > >> > > > > > > > be
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > notified about
> topology
> >> > > > changes.
> >> > > > > >> So,
> >> > > > > >> > > there
> >> > > > > >> > > > > are
> >> > > > > >> > > > > > > > > > possible
> >> > > > > >> > > > > > > > > > >> > > cases:
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > 1. ThinClient connects
> >> to a
> >> > > > > single
> >> > > > > >> > node.
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > 2. Ignite node removes
> >> > > > connection
> >> > > > > >> from
> >> > > > > >> > > > > itself.
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > I like the idea for
> the
> >> > case
> >> > > > > with a
> >> > > > > >> > > single
> >> > > > > >> > > > > > node,
> >> > > > > >> > > > > > > > as
> >> > > > > >> > > > > > > > > it
> >> > > > > >> > > > > > > > > > >> > helps
> >> > > > > >> > > > > > > > > > >> > > > fail
> >> > > > > >> > > > > > > > > > >> > > > > > > fast.
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > But is it OK to
> connect
> >> a
> >> > > > client
> >> > > > > >> to a
> >> > > > > >> > > > single
> >> > > > > >> > > > > > > node
> >> > > > > >> > > > > > > > > > only?
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > For the second one:
> you
> >> > > mention
> >> > > > > >> that a
> >> > > > > >> > > > case
> >> > > > > >> > > > > > for
> >> > > > > >> > > > > > > > the
> >> > > > > >> > > > > > > > > > >> second
> >> > > > > >> > > > > > > > > > >> > > > option
> >> > > > > >> > > > > > > > > > >> > > > > > is
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > "Long-living and
> mostly
> >> > idle
> >> > > > > >> > connections
> >> > > > > >> > > > are
> >> > > > > >> > > > > > > > > > especially
> >> > > > > >> > > > > > > > > > >> > > > > susceptible
> >> > > > > >> > > > > > > > > > >> > > > > > > to
> >> > > > > >> > > > > > > > > > >> > > > > > > > > this
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > behavior". If I
> >> understand
> >> > > > > >> correctly
> >> > > > > >> > the
> >> > > > > >> > > > > > > > connections
> >> > > > > >> > > > > > > > > > are
> >> > > > > >> > > > > > > > > > >> > > > removed
> >> > > > > >> > > > > > > > > > >> > > > > on
> >> > > > > >> > > > > > > > > > >> > > > > > > the
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > server side by client
> >> idle
> >> > > > > timeout.
> >> > > > > >> > Can
> >> > > > > >> > > we
> >> > > > > >> > > > > > just
> >> > > > > >> > > > > > > > > > >> configure
> >> > > > > >> > > > > > > > > > >> > the
> >> > > > > >> > > > > > > > > > >> > > > > idle
> >> > > > > >> > > > > > > > > > >> > > > > > > > > timeout
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > for cases where we
> >> really
> >> > > need
> >> > > > > >> keeping
> >> > > > > >> > > > alive
> >> > > > > >> > > > > > > idle
> >> > > > > >> > > > > > > > > > >> > > connections?
> >> > > > > >> > > > > > > > > > >> > > > > Are
> >> > > > > >> > > > > > > > > > >> > > > > > > > there
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > any other cases with
> >> > > > unexpectedly
> >> > > > > >> > > dropped
> >> > > > > >> > > > > > > > > connections?
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > I'm wondering is it OK
> >> to
> >> > > keep
> >> > > > > such
> >> > > > > >> > > > > > connections
> >> > > > > >> > > > > > > > > alive
> >> > > > > >> > > > > > > > > > >> for a
> >> > > > > >> > > > > > > > > > >> > > > long
> >> > > > > >> > > > > > > > > > >> > > > > > > time?
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > Also in the case of
> >> > partition
> >> > > > > >> > awareness
> >> > > > > >> > > > > > features
> >> > > > > >> > > > > > > > it
> >> > > > > >> > > > > > > > > > can
> >> > > > > >> > > > > > > > > > >> > lead
> >> > > > > >> > > > > > > > > > >> > > to
> >> > > > > >> > > > > > > > > > >> > > > > > > wasting
> >> > > > > >> > > > > > > > > > >> > > > > > > > > TCP
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > sockets on Ignite
> nodes,
> >> > > can't
> >> > > > > it?
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > Thanks!
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > On Thu, Feb 3, 2022 at
> >> 2:24
> >> > > PM
> >> > > > > >> Pavel
> >> > > > > >> > > > > Tupitsyn
> >> > > > > >> > > > > > <
> >> > > > > >> > > > > > > > > > >> > > > > > ptupit...@apache.org>
> >> > > > > >> > > > > > > > > > >> > > > > > > > > > wrote:
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >> Igniters,
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >> Please review the
> >> proposal
> >> > > to
> >> > > > > add
> >> > > > > >> > > > heartbeat
> >> > > > > >> > > > > > > > > messages
> >> > > > > >> > > > > > > > > > to
> >> > > > > >> > > > > > > > > > >> > the
> >> > > > > >> > > > > > > > > > >> > > > thin
> >> > > > > >> > > > > > > > > > >> > > > > > > > client
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >> protocol (both 2.x
> and
> >> > 3.x)
> >> > > > and
> >> > > > > >> let
> >> > > > > >> > me
> >> > > > > >> > > > know
> >> > > > > >> > > > > > > your
> >> > > > > >> > > > > > > > > > >> thoughts:
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >> > > > > > > > > > >> > >
> >> > > > > >> > > > > > > > > > >> >
> >> > > > > >> > > > > > > > > > >>
> >> > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > >
> >> > > > > >> > > > > > >
> >> > > > > >> > > > > >
> >> > > > > >> > > > >
> >> > > > > >> > > >
> >> > > > > >> > >
> >> > > > > >> >
> >> > > > > >>
> >> > > > >
> >> > > >
> >> > >
> >> >
> >>
> https://cwiki.apache.org/confluence/display/IGNITE/IEP-83+Thin+Client+Keepalive
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >>
> >> > > > > >> > > > > > > > > > >> > > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > > > --
> >> > > > > >> > > > > > > > > > >> > > > > > > > Sincerely yours, Ivan
> >> > Daschinskiy
> >> > > > > >> > > > > > > > > > >> > > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > > > --
> >> > > > > >> > > > > > > > > > >> > > > > > Sincerely yours, Ivan
> >> Daschinskiy
> >> > > > > >> > > > > > > > > > >> > > > > >
> >> > > > > >> > > > > > > > > > >> > > > >
> >> > > > > >> > > > > > > > > > >> > > >
> >> > > > > >

Reply via email to