Forums / Developer / static cache - some user report & tips ...

static cache - some user report & tips ...

Author Message

Georg Franz

Monday 27 June 2005 12:27:21 pm

Hi folks,

i am really happy with the static cache feature in ezp 3.6. The speed of my websites is fantastic now.

I've upgraded the sites
http://www.kuh.at
http://www.galaxis.at

from ezp 3.5 to 3.6.

The speed improvement is incredible ... no more fear to be nailed by search engine robots and massive multiple page requests ...

Some tips and common pitfalls:
-) If you use static cache, you have to remove all dynamic content. Sounds easy, but isn't. Most common "dynamic content" is the "user box" with the login inputs or info.

I created an article and a special override template. That article isn't cached and shows the login-box if the user is anonymous or the user information (like edit page etc.) if he is logged in.

-) If you have banners on your page you can show them with javascript.

-) If you have counter on your page, use an external service (include it with javascript) - or write your own one.

-) If you like to expire the static cache by time (e.g. you like to have a new homepage at least once a day) - create a dummy class (which isnt shown on the user site) and publish an object of this dummy class once a day in a cronjob.
(That's necerssary because deleting of the index.html isn't enough, it won't be recreated without publishing.)

-) Don't use static cache if you have 2 different sites in the same database and you are using the virtual host system.

-) Don't use staticcache if you use the "pathprefix" setting in site.ini. (I've filed a bug report already about that issue. http://ez.no/community/bugs/static_cache_path_prefix_isn_t_working_anymore )

-) If you have content like forum postings which can be created by registered users only: Think about allowing anonymous users to create them.

-) After running the makestaticcache.php you will have a lot of session entries in your ezsession table. (The scipt simulates a normal http-request, so one new session entry is produced for each page which is cached ...) So, think about clearing the session table if you have to run the script often and you have to cache thousands of pages ...

-) If you have a large site, think about the order of the static cache entries in the staticcache.ini.append:

CachedURLArray[]
CachedURLArray[]=/
CachedURLArray[]=/news
CachedURLArray[]=/news/*
CachedURLArray[]=/info
CachedURLArray[]=/info/*

Better is:
CachedURLArray[]
CachedURLArray[]=/
CachedURLArray[]=/news
CachedURLArray[]=/info
CachedURLArray[]=/news/*
CachedURLArray[]=/info/*

So in that case the /info is cached before the children of "/news" by the script.

Best wishes,
Georg.

--
http://www.schicksal.com Horoskop website which uses eZ Publish since 2004

Frederik Holljen

Tuesday 28 June 2005 1:31:32 am

Thanks for a lot of good information Georg. We are going to write a good doc page for the static cache and I'll make sure your tips are included.

Geraint Edwards

Wednesday 29 June 2005 12:50:05 am

Thanks for the pointers. If you have a minute can you clarify one of your points - you say <i>you have to remove all dynamic content</i>. Do you mean within a specific tpl file or within a "delivered" page (i.e. the final full page sent by the web server)?

* If the answer is removing dynamic content from specific tpl files (e.g. pagelayout.tpl), can you <i>include</i> external templates that encapsulate any dynamic content you wish to deliver as part of the page (I guess via shtml in the resultant static cache)?
* If the answer is removing <b>all</b> dynamic content from the served page and you have limited dynamic user/date specific content e.g. displaying user name, do you use cookies to pass the info to javascript in the page that can manipulate your "dynamic" content?

thanks

Geraint

Georg Franz

Wednesday 29 June 2005 8:34:03 am

Hi Geraint,

as you probably know meanwhile: That's the main limitation of static cache: You can't have any session information or user information and stuff like that on a page which is static.

But there should be an easy way to get the info if the current visitor is logged into the system.

For other readers: I wrote another topic for that:
http://ez.no/community/forum/developer/static_cache_get_user_login_information_by_cookie_js

Best wishes,
Georg.

--
http://www.schicksal.com Horoskop website which uses eZ Publish since 2004

Daniel Beyer

Friday 13 January 2006 10:37:36 am

Hi Georg,

we just released a patch allowing to use PathPrefix with static cache. I think you find this intersting as you already posted a bug about this issue: http://ez.no/bugs/view/6780

You can find the patch for 3.6.4 at pubsvn:
http://pubsvn.ez.no/community/trunk/hacks/staticcache_with_path_prefix/

Greetings, Daniel.

Daniel Beyer
_________________________________
YMC AG
Kreuzlingen, Switzerland
web: www.ymc.ch
____________________________________

Björn Dieding@xrow.de

Tuesday 26 February 2008 4:02:23 pm

quite old topic... not much interest anymore... I removed the sticky...

I think people should start using reverse proxies over static cache.

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Russell Michell

Sunday 06 April 2008 4:04:04 pm

"quite old topic... not much interest anymore... I removed the sticky..."

On the contrary, I would suggest there is a lot interest in what you call "Static Cache" (other descriptions are "Static content export", "Static Deployment" etc). Plone has had this functionality, allbeit as a free plug-in, for years.

The up-and-coming (very cool) Silverstripe CMS (www.silverstripe.com) already has this basic built-in and the developers are actively working on improving it for "Enterprise" class interface and functionality.

"I think people should start using reverse proxies over static cache."

For some organisations such as ours, the overhead in managing, configuring and maintaining a reverse-proxy was such that it was no-hassle at all in comparison to simply employ a system that generated flat HTML from dynamic content.

We have no use for public logins, calendar or forum functionality, just data that is occasionally requested in massive numbers - in very, very short timespan.

I am actively looking at ezPublish for a replacement for our current CMS, and its ability to create a static "cached" representation of files and file hierarchy is an absolute key component to our using it or not.

Thanks to the other posters to this thread, very useful information. :-)

Russell Michell, Wellington, New Zealand.
We're building! http://www.theruss.com/blog/
I'm on Twitter: http://twitter.com/therussdotcom

Believe nothing, consider everything.

eZ debug

Timing: Jan 18 2025 19:17:53
Script start
Timing: Jan 18 2025 19:17:53
Module start 'content'
Timing: Jan 18 2025 19:17:53
Module end 'content'
Timing: Jan 18 2025 19:17:53
Script end

Main resources:

Total runtime0.1833 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.0058 589.3828180.8281
Module start 'content' 0.00580.0054 770.2109105.9141
Module end 'content' 0.01130.1720 876.1250541.3750
Script end 0.1833  1,417.5000 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00361.9472200.0002
Check MTime0.00140.7664200.0001
Mysql Total
Database connection0.00070.400410.0007
Mysqli_queries0.138075.24521410.0010
Looping result0.00140.73671390.0000
Template Total0.171693.610.1716
Template load0.00110.596110.0011
Template processing0.170593.011110.1705
Override
Cache load0.00060.327810.0006
Sytem overhead
Fetch class attribute can translate value0.00100.542810.0010
XML
Image XML parsing0.00030.163110.0003
General
dbfile0.00281.5425200.0001
String conversion0.00000.002630.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