I've been trying to reproduce your results, and got mixed results myself.

I did a similar test with puppet-test (ignoring for a second that a major
memory abuser is the file copying) i did simple compile tests.

the setup include 3 main scenarios:

   1. latest passenger + ree
   2. passenger with RHEL5 ruby
   3. simple mongrel setup with RHEL5.

for fun, I also added a yaml/marshal comparison.

my test client was always the same with this arguments:
/puppet-test --server serverX --fork 5 --catalog_format marshal/yaml
--repeat 10

according to my calculation 60 (1+5 fork x 10) clients is at least 60
clients per minute ==> 1800 clients per puppetmaster.


my output is:
passenger + ree + marshal:
AVG: 42.4674576271186, OK: 59 failed: 1
passenger + ree + yaml:
AVG: 46.9481666666667, OK: 60 failed: 0

passenger + RHE5 ruby / marshal:
AVG: 50.6046666666667, OK: 60 failed: 0
passenger + RHE5 ruby / yaml:
AVG: 52.1456666666667, OK: 60 failed: 0

mongrel (4 processes) + with RHE5 ruby / marshal:
AVG: 48.5047272727273, OK: 55 failed: 5
mongrel (4 processes) + with RHE5 ruby / yaml:
AVG: 38.0254347826087, OK: 46 failed: 14


as it goes for memory consumptions, no surprises here, passenger processes
retain within 100mb per process, mongrel went to an average of 220mb,
however, passenger used 6 processes, and mongrel only 4.. so maybe I could
run 6 mongrels and compare further.

I did not see a huge different in memory consumption between REE and normal
RHE5 ruby when using passenger.

*in my setup, failed are clients who didnt get a catalog within 120 seconds.

Nigel, I'm surpized how you got  such a different values for compile time,
could it be that you server was swapping?

another side effect that I found in more than one occasion  that if I killed
the puppet-test, the passenger processes went on for a long time ( I killed
them manually after 15 minutes) and passenger-status reported that there are
no active processes but cpu usage was 100%.....

so bottom line so far, even if you have a balanced mongrel / cpu /client
ratio, performance-wise there is a slight difference towards ree (in my
tests), passenger is handling memory usage better than mongrels, but maybe
have some hiccups and handles high load  much better than mongrels...

Ohad


On Tue, May 12, 2009 at 9:35 AM, Nigel Kersten <nig...@google.com> wrote:

>
> This was:
>
> ruby 1.8.4 (2005-12-24) [x86_64-linux]
> vs
> ruby 1.8.6 (2008-08-11 patchlevel 287) [x86_64-linux]
> Ruby Enterprise Edition 20090421
>
> on Ubuntu Dapper, using Passenger with Apache.
>
> I used the puppet-test script in the ext/ directory to simulate 50
> simultaneous runs with a repeat of 10.  Both runs ran from the same
> clean state.
>
> I measured peak memory usage and total catalog compilation time (ie
> adding up the "compiled catalog in xxx.x seconds" output) with our
> actual Puppet configuration.
>
>
> Ruby 1.8.4:
> peak memory consumption:     2686 MB
> total catalog compilation time:  26632 seconds
>
>
> Ruby EE 20090421:
> peak memory consumption:     1462 MB
> total catalog compilation time:  13693.5 seconds
>
>
> wow.
>
>
> --
> Nigel Kersten
> nig...@google.com
> System Administrator
> Google, Inc.
>
> >
>

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-users@googlegroups.com
To unsubscribe from this group, send email to 
puppet-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/puppet-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to