Anyone tried Google mod_pagespeed on some eZ site yet?

Author Message

Ivo Lukac

Wednesday 01 December 2010 2:53:52 am

http://code.google.com/p/modpagespeed/

http://www.linkedin.com/in/ivolukac
http://www.netgen.hr/eng/blog
http://twitter.com/ilukac

Sanjay Ginde

Monday 06 December 2010 7:36:22 am

I've been playing around with mod_pagespeed in test environment. It's been working fine with eZ publish, as I was expecting. However, I have not done a true before/after performance test to see how much better it is. I think mod_pagespeed works well if you do not have an optimized apache/ezpublish configuration, as it can fill in a lot of holes. For example, you could use eZjscore to implement your JS/CSS packing, or let mod_pagespeed do it. Or you can configure your expires headers in apache manually or let pagespeed handle similar optimizations.

One feature I'm exicited to use is collapse whitespace. I had implemented the feature on a past Java web project and got significant download size gains. However, a gzip filter can compress much of that whitespace so I'm not sure what the effective gain will be. I'd love to hear more experiences with it and I'll try to add more as I test with it further. One feature I'm curious to hear more about is the image optimizer. I haven't experimented with that filter yet.

Gaetano Giunta

Monday 06 December 2010 12:14:23 pm

Agree with Sanjay: a properly tuned Apache/eZP configuration should be almost indistinguishable from a mod_pagespeed install.

. eZJscore can be used for css/js minimization and collapsing.

. a custom Imagemagick filter to strip images more aggressively. images's width and height are there because of the template for the ezimage datatype (even thought it would be nice to have it for design images too!)

. collapsing whitespace is most likely useless if you pass the response through gzip afterwards. And you can do that already within Apache or within php

. last but not least, in eZP you can implement page-level filters that are run on the generated html, once it is ready. You might add some html-optimizing code in there if you want (or a tidy filter)

Now, if we could start sending to the browser part of the page content without waiting for it to be completely generated, that would be a great improvement!

Principal Consultant International Business
Member of the Community Project Board

Nicolas Pastorino

Tuesday 07 December 2010 1:11:31 am

That all sounds pretty interesting. It should not, as Gaetano says, replace a good knowledge of eZ Publish when it comes to optimizing it, but can help reaching good performances without this knowledge, in the first round.

Not knowing much about Google mod_pagespeed, do you guys know if there are other built-in improvements which we do not yet find in eZ Publish or affiliate extensions ?

Cheers !

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Damien Pobel

Tuesday 07 December 2010 11:06:10 am

Hi,

I've not tested mod_pagespeed myself as I prefer hand made optimisations. But you should have a look at mod_Pagespeed Performance Review published on the performance advent calendar.

Cheers

Damien
Planet eZ Publish.fr : http://www.planet-ezpublish.fr
Certification : http://auth.ez.no/certification/verify/372448
Publications about eZ Publish : http://pwet.fr/tags/keywords/weblog/ez_publish

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 02:22:27
Script start
Timing: Jan 18 2025 02:22:27
Module start 'layout'
Timing: Jan 18 2025 02:22:27
Module start 'content'
Timing: Jan 18 2025 02:22:27
Module end 'content'
Timing: Jan 18 2025 02:22:27
Script end

Main resources:

Total runtime0.0168 sec
Peak memory usage4,096.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 589.5000152.6406
Module start 'layout' 0.00570.0040 742.140639.4844
Module start 'content' 0.00970.0052 781.625097.3516
Module end 'content' 0.01500.0018 878.976638.2891
Script end 0.0167  917.2656 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002816.6617140.0002
Check MTime0.00127.0080140.0001
Mysql Total
Database connection0.00084.703810.0008
Mysqli_queries0.003319.549430.0011
Looping result0.00000.119610.0000
Template Total0.00148.210.0014
Template load0.00074.155810.0007
Template processing0.00074.029110.0007
Override
Cache load0.00052.793810.0005
General
dbfile0.00031.882980.0000
String conversion0.00000.054140.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs