Forums / Install & configuration / How far can I take static cache?

How far can I take static cache?

Author Message

Seth Gottlieb

Tuesday 13 March 2007 7:53:21 pm

I am working with a client that would prefer a "baking" style CMS where all the pages are pre-generated and then served by a basic web server. How close can static cache get to this model?

If I set

CachedURLArray[]=/*

Will every page on the site get cached? What overhead would eZ publish add? For example, does it query the database to translate virtual urls to system urls? Does index.php stream down the contents of the html files cached on the file system?

Also, are any really high traffic sites intensively using static cache?

Thanks,

Seth

Christian Johansen

Wednesday 14 March 2007 2:54:22 am

You can take static cache all the way! :) There's no faster way to serve eZ Publish pages. You can even get away with a server that doesn't even have PHP installed if you either move the cache files manually or with a script of some sort.

eZ Publish creates a static cache by generating fully functional static HTML pages and then uses Apache mod_rewrite to redirect directly to these files if they exist. This means that when a page is statically cached, the request won't even get to eZ Publish at all. It goes straight from the .htaccess (or VirtualHost in httpd.conf) rewrite to the html file.

Seth Gottlieb

Wednesday 14 March 2007 7:19:09 am

This is perfect. Is there any documentation that shows how to configure a site in this way?

Bruce Morrison

Wednesday 14 March 2007 6:02:19 pm

Hi Seth

There are a number of things to watch with the static cache:
+ If a static copy of a pages doesn't exist on the file system then eZ is used to serve the page.
+ You manually generate the initial static cache then pages are regenerated after publishing. Beware running this script on a running sight as it removes the static cache before regenerating it. This means that the site relies on eZ while the static cache is generated.
+ You have to make sure that the setup regenerates all the effected pages otherwise you can end up with old/dirty content on the site.
+ Only works for parts of the site that do not require login. If any part of the pagelayout is changed when the user logs in (basket, login form, personalisation etc) then you might need to reconsider the page design.
+ Of course will not work with things like search. (I'm pretty sure it is limited to the content module)
+ On heavily loaded sites it is good to use view cache pre-generation along with static caching as this minimises the time it takes to create the static version of the page.

The static cache is great in that you can run a site with much lower speced hardware than if you use just eZ to serve the pages. If you remove the cache for any reason you might find yourself in trouble :)

I've used the static caching on a site that is pretty quite for all but 4 days of the year. During those 4 days it goes off - lots of accesses and lots of updates. We used the static cache to help handle the load.

We did find that the updates meant that pages like the home page were being generated quite often and the system was falling back to eZ to server the page.

I ended up writing an extension that allowed for the content updates to be done in batches and for the static pages to be generated manually. I'll see about packaging it putting it up as a contribution.

In some cases we've also used wget to generate static versions of eZ sites. This may be a simpler solution.

Heres a couple of links
http://ez.no/doc/ez_publish/technical_manual/3_6/reference/configuration_files/staticcache_ini
http://ez.no/community/articles/ez_publish_performance_optimization_part_3_of_3_practical_cache_and_template_solutions/static_cache
http://ez.no/community/forum/developer/static_cache_some_user_report_tips

Cheers
Bruce

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

eZ debug

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

Main resources:

Total runtime0.3526 sec
Peak memory usage4,096.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0080 587.8281180.8281
Module start 'content' 0.00800.0067 768.656398.0547
Module end 'content' 0.01470.3378 866.7109526.5781
Script end 0.3525  1,393.2891 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00381.0705200.0002
Check MTime0.00140.3946200.0001
Mysql Total
Database connection0.00100.278810.0010
Mysqli_queries0.302085.66201410.0021
Looping result0.00150.41701390.0000
Template Total0.337595.710.3375
Template load0.00110.308910.0011
Template processing0.336495.412010.3364
Override
Cache load0.00080.235110.0008
Sytem overhead
Fetch class attribute can translate value0.00080.233710.0008
XML
Image XML parsing0.00030.080810.0003
General
dbfile0.00391.1033200.0002
String conversion0.00000.002330.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/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