Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

Poor performance of Ruby 1.8.7 when installed with MacPorts

5 views
Skip to first unread message

abc

unread,
Nov 1, 2008, 6:59:24 AM11/1/08
to
Hi,

I've just upgraded to Ruby 1.8.7 using MacPorts (ruby @1.8.7-
p72_1+thread_hooks) and while it runs flawlessly, the performance is
really really poor.

I'm talking in comparison with the Ruby distro that ships with
Leopard, and with my previous installation of 1.8.6 also done with
MacPorts.

For instance a bunch of rspecs i have take 6x to get executed, and ri
takes noticeably more time than previously to load any doc.

Is anyone experiencing the same problem? Do you know how to fix it?

Thanks in advance.

Brian Adkins

unread,
Nov 1, 2008, 12:46:59 PM11/1/08
to

abc

unread,
Nov 2, 2008, 6:34:39 AM11/2/08
to
Fine, thanks for the info.

Do you know what is the exact issue with MacPorts though?

nakatani katsumi

unread,
Nov 3, 2008, 5:01:36 AM11/3/08
to
Hi

On Sat, 1 Nov 2008 19:58:54 +0900
abc <arcadioru...@gmail.com> wrote:

> I've just upgraded to Ruby 1.8.7 using MacPorts (ruby @1.8.7-
> p72_1+thread_hooks) and while it runs flawlessly, the performance is
> really really poor.

> Is anyone experiencing the same problem? Do you know how to fix it?
The same problem reported at ruby-list-45593.(but Japanese only)

Summary is below.
1. On MacOS X(10.5.5), Ruby1.8.7(p72) compiled with --enable-pthread excute slowly,
as Ruby use time of 70% at rb_call()->getcontext() in fib.rb

2. In MacPorts, ./configure with --enable-pthread option makes config.h using getcontext
like below
#define HAVE_GETCONTEXT 1
#define HAVE_SETCONTEXT 1

3. If you comment out these two lines, you will get normal speed Ruby1.8.7.

4. As Ruby1.9 don't use getcontext()/setcontext(), Ruby1.9 don't care --enable-pthread.

abc

unread,
Nov 4, 2008, 8:22:47 AM11/4/08
to
Thanks for the explanation!

abc

unread,
Nov 6, 2008, 1:30:29 PM11/6/08
to
I filed a bug report and they've just fixed it:

http://trac.macports.org/ticket/17092

Brian Adkins

unread,
Nov 6, 2008, 11:18:12 PM11/6/08
to
abc <arcadioru...@gmail.com> writes:

> I filed a bug report and they've just fixed it:
>
> http://trac.macports.org/ticket/17092

Wow, that was fast. Is the Ruby community great, or what? :) Thanks
for reporting back with the info.

--
Brian Adkins
http://www.lojic.com/
http://lojic.com/blog/

Nit Khair

unread,
Nov 6, 2008, 11:55:34 PM11/6/08
to
nakatani katsumi wrote:
> Hi
>
> On Sat, 1 Nov 2008 19:58:54 +0900
> abc <arcadioru...@gmail.com> wrote:
>
>> I've just upgraded to Ruby 1.8.7 using MacPorts (ruby @1.8.7-
>> p72_1+thread_hooks) and while it runs flawlessly, the performance is
>> really really poor.

Could someone explain this to to me. I checked the macports page a few
days back and it said it disables/deletes -enable-pthreads due to some
bug. So does that not mean that it's not there. As pointed above, it
uses thread_hooks instead.

1. Is there any commandline option or other way of my ascertaining
whether my install uses pthreads or not.

Another newb question:

2. One of the prev posts suggests altering config.h and running
/configure. However, if one is using sudo port install how does one do
this? I do not have a "configure" in my ruby folder and my config.h
(/opt/local/var/macports/software/ruby/1.8.7-p22_3+darwin_9_powerpc+thread_hooks/opt/local/lib/ruby/1.8/powerpc-darwin9.4.0/config.h)
does not contain GETCONTEXT.

Thanks.
--
Posted via http://www.ruby-forum.com/.

Roger Pack

unread,
Nov 7, 2008, 4:36:23 PM11/7/08
to
> Could someone explain this to to me. I checked the macports page a few
> days back and it said it disables/deletes -enable-pthreads due to some
> bug. So does that not mean that it's not there. As pointed above, it
> uses thread_hooks instead.

apparently somebody said that the most recent macport of it now compiles
with pthreads disabled.

>
> 1. Is there any commandline option or other way of my ascertaining
> whether my install uses pthreads or not.

from [1]
Maybe try with "ldd" on the ruby binaries--can't remember what the mac
equivalent is but it exists.


> Another newb question:
>
> 2. One of the prev posts suggests altering config.h and running

> ./configure. However, if one is using sudo port install how does one do

> this? I do not have a "configure" in my ruby folder and my config.h
> (/opt/local/var/macports/software/ruby/1.8.7-p22_3+darwin_9_powerpc+thread_hooks/opt/local/lib/ruby/1.8/powerpc-darwin9.4.0/config.h)
> does not contain GETCONTEXT.

If you install it from source you should be able to get at it
right...not sure using macports.

GL.
-=R

[1]
http://groups.google.com/group/comp.lang.ruby/browse_thread/thread/a31872d447e867cb/40a92a28e9e03793

Luc Heinrich

unread,
Nov 8, 2008, 3:53:42 AM11/8/08
to
On 7 nov. 08, at 22:36, Roger Pack wrote:

> If you install it from source you should be able to get at it
> right...not sure using macports.

Using MacPorts, you just have to perform the various steps of the
'install' task manually, like this:

% sudo port fetch ruby
% sudo port extract ruby
% sudo port configure ruby

Now go in the work directory and change what you need. You can see
where that directory is by typing:
% port file ruby

After that, you can continue normally:
% sudo port install ruby

--
Luc Heinrich - l...@honk-honk.com


Nit Khair

unread,
Nov 8, 2008, 6:24:16 AM11/8/08
to
Luc Heinrich wrote:
> On 7 nov. 08, at 22:36, Roger Pack wrote:
>
>> If you install it from source you should be able to get at it
>> right...not sure using macports.
>
> Using MacPorts, you just have to perform the various steps of the
> 'install' task manually, like this:
>
Thanks a lot.

btw, will installing 1.9 from macports create a separate executable such
as ruby1.9 so we can run 8 and 9 in parallel. Or overwrite?


Is there any way via macports to have both running in parallel.
Thanks.

Luc Heinrich

unread,
Nov 8, 2008, 9:41:13 AM11/8/08
to
On 8 nov. 08, at 12:24, Nit Khair wrote:

> btw, will installing 1.9 from macports create a separate executable
> such
> as ruby1.9 so we can run 8 and 9 in parallel. Or overwrite?

The ruby19 Portfile sets the --program-suffix argument of configure to
1.9, so yes you could install Ruby 1.8 and Ruby 1.9 at the same time
on the same machine.

Jason Lai

unread,
Nov 24, 2008, 11:55:16 PM11/24/08
to
Hi Nakatani-san,

That was really helpful information. I digged a bit more based upon
that thread, and for those who compile Ruby 1.8.7 from source on OS X,
here's a more handy way: add 'ac_cv_func_getcontext=no
ac_cv_func_setcontext=no' along with --enable-pthread, e.g.:
./configure --enable-pthread --enable-shared ac_cv_func_getcontext=no
ac_cv_func_setcontext=no

Then the following lines won't appear on your config.h:


#define HAVE_GETCONTEXT 1
#define HAVE_SETCONTEXT 1

Just my 2 cents,
Jason

On 11月3日, 下午6时01分, nakatani katsumi <al...@kcat.zaq.ne.jp> wrote:
> Hi
>
> On Sat, 1 Nov 2008 19:58:54 +0900
>

nakatani katsumi

unread,
Nov 28, 2008, 8:00:02 AM11/28/08
to
Hi Jason

On Tue, 25 Nov 2008 13:55:31 +0900
Jason Lai <ja...@jasonlai.net> wrote:

> Hi Nakatani-san,
>
> That was really helpful information. I digged a bit more based upon
> that thread, and for those who compile Ruby 1.8.7 from source on OS X,
> here's a more handy way: add 'ac_cv_func_getcontext=no
> ac_cv_func_setcontext=no' along with --enable-pthread, e.g.:

Oh,I missed to follow this problem.
This bug was fixed with 1.8.7-p72_2 of MacPorts, that was reported at
ruby-list:45621(japanese only).
(ruby 1.8.7-p72_1 of MacPorts has bug)
You can use the most up-to-date ruby of MacPorts without any extra option.

--
nakatani katsumi <al...@kcat.zaq.ne.jp>

Jason Lai

unread,
Dec 2, 2008, 1:45:05 PM12/2/08
to
Hi Nakatani-san,

Thanks for the heads-up. But the issue is still there for those
compiling Ruby 1.8.7-p72 from source right? If so, my little tip may
be of some help.

Cheers,
Jason

0 new messages