[#53072] [ruby-trunk - Feature #7994][Open] Make iterators pass an implicit named parameter `iteration` to the executed block — "alexeymuranov (Alexey Muranov)" <redmine@...>

10 messages 2013/03/01

[#53097] [ruby-trunk - Bug #8000][Open] "require 'tk'" segfaults on 64-bit linux with Tk 8.6 — "edmccard (Ed McCardell)" <edmccard@...>

25 messages 2013/03/02

[#53137] [ruby-trunk - Bug #8017][Open] Got segmentation fault on attempt to install ruby 2.0.0-p0 on Mac 10.6.8 via RVM — "adantel (Alex Filatau)" <filatau@...>

9 messages 2013/03/05

[#53168] [ruby-trunk - Bug #8034][Open] File.expand_path('something', '~') do not include home path — "rap-kasta (Pavel Manylov)" <rapkasta@...>

12 messages 2013/03/06

[#53199] [ruby-trunk - Bug #8040][Open] Unexpect behavior when using keyword arguments — "pabloh (Pablo Herrero)" <pablodherrero@...>

11 messages 2013/03/07

[#53203] [ruby-trunk - Feature #8042][Open] Add Addrinfo#socket to create a socket that is not connected or bound — "drbrain (Eric Hodel)" <drbrain@...7.net>

12 messages 2013/03/07

[#53248] Github commit log should not be used as references on redmine — Marc-Andre Lafortune <ruby-core-mailing-list@...>

Github commit log should not be used as references on redmine. E.g:

10 messages 2013/03/09

[#53386] [CommonRuby - Feature #8088][Open] Method#parameters (and friends) should provide useful information about core methods — "headius (Charles Nutter)" <headius@...>

14 messages 2013/03/13

[#53412] [CommonRuby - Feature #8096][Open] introduce Time.current_timestamp — "vipulnsward (Vipul Amler)" <vipulnsward@...>

34 messages 2013/03/14

[#53439] [ruby-trunk - Bug #8100][Open] Segfault in ruby-2.0.0p0 — "judofyr (Magnus Holm)" <judofyr@...>

22 messages 2013/03/15

[#53478] [ruby-trunk - Feature #8107][Open] [patch] runtime flag to track object allocation metadata — "tmm1 (Aman Gupta)" <ruby@...1.net>

20 messages 2013/03/16

[#53498] [ruby-trunk - Feature #8110][Open] Regex methods not changing global variables — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

21 messages 2013/03/18

[#53502] [ruby-trunk - Bug #8115][Open] make install DESTDIR=/my/install/path fails — "vo.x (Vit Ondruch)" <v.ondruch@...>

11 messages 2013/03/18

[#53688] [ruby-trunk - Feature #8158][Open] lightweight structure for loaded features index — "funny_falcon (Yura Sokolov)" <funny.falcon@...>

27 messages 2013/03/24

[#53692] [ruby-trunk - Bug #8159][Open] Build failure introduced by Rinda changes — "luislavena (Luis Lavena)" <luislavena@...>

22 messages 2013/03/24

[#53733] [ruby-trunk - Bug #8165][Open] Problems with require — "Krugloff (Alexandr Kruglov)" <mr.krugloff@...>

12 messages 2013/03/26

[#53742] [ruby-trunk - Bug #8168][Open] Feature request: support for (single) statement lambda syntax/definition — "garysweaver (Gary Weaver)" <garysweaver@...>

9 messages 2013/03/26

[#53765] [ruby-trunk - Bug #8174][Open] AIX header file conflict with rb_hook_list_struct — "edelsohn (David Edelsohn)" <dje.gcc@...>

11 messages 2013/03/27

[#53808] [ruby-trunk - Feature #8181][Open] New flag for strftime that supports adding ordinal suffixes to numbers — "tkellen (Tyler Kellen)" <tyler@...>

10 messages 2013/03/28

[#53811] [ruby-trunk - Bug #8182][Open] XMLRPC request fails with "Wrong size. Was 31564, should be 1501" — "tsagadar (Marcel Mueller)" <marcel.mueller@...>

28 messages 2013/03/28

[#53849] [ruby-trunk - Feature #8191][Open] Short-hand syntax for duck-typing — "wardrop (Tom Wardrop)" <tom@...>

48 messages 2013/03/31

[#53850] An evaluation of 2.0.0 release — Yusuke Endoh <mame@...>

Let's look back at 2.0.0 release so that we can do better next time.

12 messages 2013/03/31

[ruby-core:53690] [ruby-trunk - Feature #8119] more efficient version of Rinda::TupleSpaceProxy.take

From: "seki (Masatoshi Seki)" <seki@...>
Date: 2013-03-24 09:15:06 UTC
List: ruby-core #53690
Issue #8119 has been updated by seki (Masatoshi Seki).

Assignee changed from seki (Masatoshi Seki) to drbrain (Eric Hodel)


----------------------------------------
Feature #8119: more efficient version of Rinda::TupleSpaceProxy.take
https://bugs.ruby-lang.org/issues/8119#change-37875

Author: vjoel (Joel VanderWerf)
Status: Assigned
Priority: Normal
Assignee: drbrain (Eric Hodel)
Category: lib
Target version: 


=begin

The purpose of Rinda::TupleSpaceProxy is to avoid losing tuples when a client disconnects during a #take call. This is implemented by sending the result value ((*twice*)): first by pushing it to a client-side array, second by returning the result as a DRb response. If the first fails, then the #take is aborted, so that the tuple is not lost. In case of success, the client only uses the pushed value, not the response value.

This involves a total of ((*three*)) marshal operations by DRb: the push argument, the push return value (which is an array containing the push argument), and the #take return value. Only the first is necessary.

The following patch adds Rinda::TupleSpaceProxy#take_fast, which avoids the two redundant marshal operations. The unit tests in the ruby source pass when calling this method instead of #take.

The improvement is small when the object is simple. However, for complex objects, eliminating the redundant marshalling reduces network traffic and increases speed by a factor of 2. See the attached bench.rb.


  diff --git a/rinda/rinda.rb b/rinda/rinda.rb
  index 18e284a..5d280f4 100644
  --- a/rinda/rinda.rb
  +++ b/rinda/rinda.rb
  @@ -206,6 +206,13 @@ module Rinda
     # TupleSpaceProxy allows a remote Tuplespace to appear as local.

     class TupleSpaceProxy
  +    class Port
  +      attr_reader :val
  +      def push val
  +        @val = val
  +        nil # so that val doesn't get marshalled again
  +      end
  +    end

       ##
       # Creates a new TupleSpaceProxy to wrap +ts+.
  @@ -223,6 +230,17 @@ module Rinda

       ##
       # Takes +tuple+ from the proxied TupleSpace.  See TupleSpace#take.
  +    # This is sometimes a bit faster than #take bacause it uses a version
  +    # of TupleSpace#move that never marshals the result more than once.
  +
  +    def take_fast(tuple, sec=nil, &block)
  +      port = Port.new
  +      @ts.move_fast(DRbObject.new(port), tuple, sec, &block)
  +      port.val
  +    end
  +
  +    ##
  +    # Takes +tuple+ from the proxied TupleSpace.  See TupleSpace#take.

       def take(tuple, sec=nil, &block)
         port = []
  diff --git a/rinda/tuplespace.rb b/rinda/tuplespace.rb
  index ba494aa..042c605 100644
  --- a/rinda/tuplespace.rb
  +++ b/rinda/tuplespace.rb
  @@ -480,6 +480,43 @@ module Rinda
       end

       ##
  +    # Moves +tuple+ to +port+, returning nil
  +
  +    def move_fast(port, tuple, sec=nil)
  +      template = WaitTemplateEntry.new(self, tuple, sec)
  +      yield(template) if block_given?
  +      synchronize do
  +        entry = @bag.find(template)
  +        if entry
  +          port.push(entry.value)
  +          @bag.delete(entry)
  +          notify_event('take', entry.value)
  +          return nil
  +        end
  +        raise RequestExpiredError if template.expired?
  +
  +        begin
  +          @take_waiter.push(template)
  +          start_keeper if template.expires
  +          while true
  +            raise RequestCanceledError if template.canceled?
  +            raise RequestExpiredError if template.expired?
  +            entry = @bag.find(template)
  +            if entry
  +              port.push(entry.value)
  +              @bag.delete(entry)
  +              notify_event('take', entry.value)
  +              return nil
  +            end
  +            template.wait
  +          end
  +        ensure
  +          @take_waiter.delete(template)
  +        end
  +      end
  +    end
  +
  +    ##
       # Moves +tuple+ to +port+.

       def move(port, tuple, sec=nil)


=end



-- 
http://bugs.ruby-lang.org/

In This Thread