[#59462] [ruby-trunk - Bug #9342][Open] [PATCH] SizedQueue#clear does not notify waiting threads in Ruby 1.9.3 — "jsc (Justin Collins)" <redmine@...>

9 messages 2014/01/02

[#59466] [ruby-trunk - Bug #9343][Open] [PATCH] SizedQueue#max= wakes up waiters properly — "normalperson (Eric Wong)" <normalperson@...>

11 messages 2014/01/02

[#59498] [ruby-trunk - Bug #9352][Open] [BUG] rb_sys_fail_str(connect(2) for [fe80::1%lo0]:3000) - errno == 0 — "kain (Claudio Poli)" <claudio@...>

10 messages 2014/01/03

[#59516] [ruby-trunk - Bug #9356][Open] TCPSocket.new does not seem to handle INTR — "charliesome (Charlie Somerville)" <charliesome@...>

48 messages 2014/01/03

[#59538] [ruby-trunk - Feature #9362][Assigned] Minimize cache misshit to gain optimal speed — "shyouhei (Shyouhei Urabe)" <shyouhei@...>

33 messages 2014/01/03
[#59582] Re: [ruby-trunk - Feature #9362][Assigned] Minimize cache misshit to gain optimal speed — SASADA Koichi <ko1@...> 2014/01/06

Intersting challenge.

[#59541] Re: [ruby-trunk - Feature #9362][Assigned] Minimize cache misshit to gain optimal speed — Eric Wong <normalperson@...> 2014/01/04

Hi, I noticed a trivial typo in array.c, and it fails building struct.c

[#59583] [ruby-trunk - Bug #9367][Open] REXML::XmlDecl doesn't use user specified quotes — "bearmini (Takashi Oguma)" <bear.mini@...>

12 messages 2014/01/06

[#59642] [ruby-trunk - Bug #9384][Open] Segfault in ruby 2.1.0p0 — "cbliard (Christophe Bliard)" <christophe.bliard@...>

11 messages 2014/01/08

[#59791] About unmarshallable DRb objects life-time — Rodrigo Rosenfeld Rosas <rr.rosas@...>

A while ago I created a proof-of-concept that I intended to use in my

16 messages 2014/01/15
[#59794] Re: About unmarshallable DRb objects life-time — Eric Hodel <drbrain@...7.net> 2014/01/15

On 15 Jan 2014, at 11:58, Rodrigo Rosenfeld Rosas <rr.rosas@gmail.com> wrote:

[#59808] Re: About unmarshallable DRb objects life-time — Rodrigo Rosenfeld Rosas <rr.rosas@...> 2014/01/16

Em 15-01-2014 19:42, Eric Hodel escreveu:

[#59810] Re: About unmarshallable DRb objects life-time — Eric Hodel <drbrain@...7.net> 2014/01/16

On 16 Jan 2014, at 02:15, Rodrigo Rosenfeld Rosas <rr.rosas@gmail.com> wrote:

[#59826] Re: About unmarshallable DRb objects life-time — Rodrigo Rosenfeld Rosas <rr.rosas@...> 2014/01/17

Em 16-01-2014 19:43, Eric Hodel escreveu:

[#59832] Re: About unmarshallable DRb objects life-time — Eric Hodel <drbrain@...7.net> 2014/01/17

On 17 Jan 2014, at 04:22, Rodrigo Rosenfeld Rosas <rr.rosas@gmail.com> wrote:

[ruby-core:59995] Re: About unmarshallable DRb objects life-time

From: Rodrigo Rosenfeld Rosas <rr.rosas@...>
Date: 2014-01-22 21:17:16 UTC
List: ruby-core #59995
Good point. I'll try to find some time to implement and test this
keep-alive suggestion.

Thank you :-)
Em 22/01/2014 19:07, "Eric Hodel" <drbrain@segment7.net> escreveu:

> On 22 Jan 2014, at 03:20, Rodrigo Rosenfeld Rosas <rr.rosas@gmail.com>
> wrote:
> >>> But in the case where the returned DRb objects will always hold a
> reference to all required objects created in the server-side, there remains
> another problem. How do I detect that the objects have been collected in
> the client-side so that I could free them in the server-side as well? This
> has always been my main concern with regards to manually keeping a
> reference by artificial means in the server-side.
> >> A context object allocated on the server and explicitly terminated from
> the client when it is finished using the service can overcome this problem.
> >
> > But the problem is that with a transparent server the client won't
> explicitly terminate anything or it would be a too complex service to use
> and very error-prone.
> >
> >> The context object could communicate with the id conversion handler
> either by tracking peers (possibly difficult) or through time stamps on
> created references.  A keep-alive mechanism would allow the context object
> to auto-expire.
> >
> > The idea of auto-expire is actually pretty good since we already have an
> upper bound for non-streaming responses of 60s (nginx timeout). But the
> problem remains with streamed responses as they could take longer than 1
> minute.
>
>
> Rinda痴 Renewer handles this type of problem through the use of keep-alive
> callbacks.
>
> > But maybe using ObjectSpace.define_finalizer would take care of freeing
> the references in the server-side. In that case, I'd still need to worry
> about the drb connection being closed. Is there anyway I could detect any
> connection close from the DRb server-side so that I could remove all
> references to objects created using that connection?
>
> I think ObjectSpace.define_finalizer will be harder to implement correctly
> than keep-alive callbacks.  For example, what happens if the client uses a
> finalizer to destroy a remote object what happens for network failures or
> client crashes?
>
> For the keep-alive callback, if the timeout is greater than the expected
> request duration you should be OK even when there is a temporary network
> failure.

In This Thread

Prev Next