[#27380] [Bug #2553] Fix pthreads slowness by eliminating unnecessary sigprocmask calls — Dan Peterson <redmine@...>

Bug #2553: Fix pthreads slowness by eliminating unnecessary sigprocmask calls

21 messages 2010/01/03

[#27437] [Feature #2561] 1.8.7 Patch reduces time cost of Rational operations by 50%. — Kurt Stephens <redmine@...>

Feature #2561: 1.8.7 Patch reduces time cost of Rational operations by 50%.

9 messages 2010/01/06

[#27447] [Bug #2564] [patch] re-initialize timer_thread_{lock,cond} after fork — Aliaksey Kandratsenka <redmine@...>

Bug #2564: [patch] re-initialize timer_thread_{lock,cond} after fork

18 messages 2010/01/06

[#27635] [Bug #2619] Proposed method: Process.fork_supported? — Hongli Lai <redmine@...>

Bug #2619: Proposed method: Process.fork_supported?

45 messages 2010/01/20
[#27643] [Feature #2619] Proposed method: Process.fork_supported? — Luis Lavena <redmine@...> 2010/01/21

Issue #2619 has been updated by Luis Lavena.

[#27678] Re: [Feature #2619] Proposed method: Process.fork_supported? — Yukihiro Matsumoto <matz@...> 2010/01/22

Hi,

[#27684] Re: [Feature #2619] Proposed method: Process.fork_supported? — Charles Oliver Nutter <headius@...> 2010/01/22

On Thu, Jan 21, 2010 at 11:27 PM, Yukihiro Matsumoto <matz@ruby-lang.org> w=

[#27708] Re: [Feature #2619] Proposed method: Process.fork_supported? — Yukihiro Matsumoto <matz@...> 2010/01/22

Hi,

[#27646] Re: [Bug #2619] Proposed method: Process.fork_supported? — Tanaka Akira <akr@...> 2010/01/21

2010/1/21 Hongli Lai <redmine@ruby-lang.org>:

[#27652] Re: [Bug #2619] Proposed method: Process.fork_supported? — Hongli Lai <hongli@...99.net> 2010/01/21

On 1/21/10 5:20 AM, Tanaka Akira wrote:

[#27653] Re: [Bug #2619] Proposed method: Process.fork_supported? — Tanaka Akira <akr@...> 2010/01/21

2010/1/21 Hongli Lai <hongli@plan99.net>:

[#27662] Re: [Bug #2619] Proposed method: Process.fork_supported? — Vladimir Sizikov <vsizikov@...> 2010/01/21

On Thu, Jan 21, 2010 at 10:53 AM, Tanaka Akira <akr@fsij.org> wrote:

[#27698] [Bug #2629] ConditionVariable#wait(mutex, timeout) should return whether the condition was signalled, not the waited time — Hongli Lai <redmine@...>

Bug #2629: ConditionVariable#wait(mutex, timeout) should return whether the condition was signalled, not the waited time

8 messages 2010/01/22

[#27722] [Feature #2635] Unbundle rdoc — Yui NARUSE <redmine@...>

Feature #2635: Unbundle rdoc

14 messages 2010/01/23

[#27757] [Bug #2638] ruby-1.9.1-p37[68] build on aix5.3 with gcc-4.2 failed to run for me because it ignores where libgcc is located. — Joel Soete <redmine@...>

Bug #2638: ruby-1.9.1-p37[68] build on aix5.3 with gcc-4.2 failed to run for me because it ignores where libgcc is located.

10 messages 2010/01/24

[#27778] [Bug #2641] Seg fault running miniruby during ruby build on Haiku — Alexander von Gluck <redmine@...>

Bug #2641: Seg fault running miniruby during ruby build on Haiku

10 messages 2010/01/25

[#27791] [Bug #2644] memory over-allocation with regexp — Greg Hazel <redmine@...>

Bug #2644: memory over-allocation with regexp

12 messages 2010/01/25

[#27794] [Bug #2647] Lack of testing for String#split — Hugh Sasse <redmine@...>

Bug #2647: Lack of testing for String#split

14 messages 2010/01/25

[#27912] [Bug #2669] mkmf find_executable doesn't find .bat files — Roger Pack <redmine@...>

Bug #2669: mkmf find_executable doesn't find .bat files

11 messages 2010/01/27

[#27930] [Bug:trunk] some behavior changes of lib/csv.rb between 1.8 and 1.9 — Yusuke ENDOH <mame@...>

Hi jeg2, or anyone who knows the implementation of FasterCSV,

15 messages 2010/01/28
[#27931] Re: [Bug:trunk] some behavior changes of lib/csv.rb between 1.8 and 1.9 — James Edward Gray II <james@...> 2010/01/28

On Jan 28, 2010, at 10:51 AM, Yusuke ENDOH wrote:

[ruby-core:27576] Re: better GC?

From: Brent Roman <brent@...>
Date: 2010-01-13 01:54:25 UTC
List: ruby-core #27576
The main point of this particular GC algorithm was to reduce the maximum=20
latency it imposed.  It seems to manage this very well in a way that's
compatible with
the existing MRI structure.  But, the cost is that long-term average
throughput may
be reduced by 10% or so.  Most incremental algorithms are not as fast as
those
that don't allow for interruption.

So, as you point out, if you've got all your cores and hyperthreads fully
utilized, this GC will hurt average throughput.

However, I'd submit that:

1)  most systems running Ruby today have multiple cores and/or
hyperthreading

2)  Desktop systems rarely keep all their cores busy,

3)  the more cores you have, the more likely it is that one or more is not=
=20
being fully utilized at any given instant.  It's really hard to keep an
8-core server
CPU bound for extended periods, especially when it's serving the web pages.

So, most Ruby installations would see a net increase in throughput with thi=
s
GC.
But, again, that's not its main design goal.  Reducing latency is. =20
10ms max latency would eliminate the GC induces freezes that distract users
and=20
allow Ruby to be used more in financial, robotics, audio and video
processing.

- brent



Kirk Haines wrote:
>=20
> On Tue, Jan 12, 2010 at 1:11 PM, Kurt Stephens <ks@kurtstephens.com>
> wrote:
>=20
>> =C2=A0If that's the case, then no one would use multi-core processors at=
 all.
>> =C2=A0How the threads are mapped to a processor (i.e. another core or no=
t) is
>> an
>> OS issue.
>=20
> Maybe you miss my point?  See below.
>=20
>> =C2=A0The issue here is that the majority of the work can be done in a
>> separate
>> thread which allows the mutator (in this case Ruby) to continue
>> =C2=A0while the GC's thread is doing its job.
>=20
> If I have one core, under that particular GC scheme, my stuff runs 10%
> slower.
>=20
> If I have two cores, my stuff runs X% faster, because a bunch of the
> GC work is offloaded to that second core.
>=20
> So, if I have my code already running on two cores, there aren't any
> more idle cores available to actually offload GC work to.  So my code
> on both cores is now running 10% slower.
>=20
> i.e. overall, we're doing more work to get a certain execution time or
> throughput on our code using the Boehm conservative GC mentioned, but
> that GC can spread the work out among more cores, so if the machine
> isn't already running at max CPU capacity, that one job can appear to
> run faster, but that breaks down if all of the cores are being
> utilized for work.  For example, let's say that I have a 4 core
> machine. I'm running some code on it that, when pushed to its limits,
> utilizes all four cores at 100%.
>=20
> ...
>=20
> Kirk Haines
>=20
>=20
>=20

--=20
View this message in context: http://old.nabble.com/-ruby-core%3A27135--bet=
ter-GC--tp26735247p27138333.html
Sent from the ruby-core mailing list archive at Nabble.com.


In This Thread