Forums / Setup & design / Questions about good tpl design for Static Caching

Questions about good tpl design for Static Caching

Author Message

Massimiliano Bariola

Wednesday 22 February 2006 5:36:39 am

Hi,

I am looking forward to activate static caching on a high-traffic website, and had some questions for those who are experienced in its use so to avoid problems later.

All of this revolves around the use of navigator/google.tpl which caused me some cache-related problems when I used it on earlier projects. maybe these can be avoided with a cleverer design springing up from your suggestions :-)

I have some override templates for specific folders which list their content as a formatted list. for big amounts of items, this list is paged - so google.tpl serves just this purpose.

the google.tpl include is placed at the end of the "full" override template for the folder.

let's suppose I have 2 of these list folders accessible at /foo/list1 and /foo/list2.

When I have viewcaching, contentcaching, templatecompile and templatecaching on, and I access /foo/list1, google.tpl generates links like /foo/list1/(offset)/10, /foo/list1/(offset)/20, etc. so far, so good!

however, when I access /foo/list2, google.tpl will generate links like /foo/list1/(offset)/10 and so on. thus using the first accessed node , list1 , as a base. eek!.

I don't know whether this is connected to ViewCaching or to TemplateCompile or TemplateCaching, but let's say I worked around this, by using cache-blocks and leaving the google.tpl out of them.

So, now I have a site which is working with "regular" caching, at the expense of the need to use some tricks (disable cache, enable cache for all tpl save the google.tpl and so )

Now I want to use static cache. by definition, static cache generator renders all the full templates of all content nodes. Enter those folders with big amounts of items and let's assume that the HTML content is correctly generated for all nodes.

The problem here is, there are some classes which do not have a full.tpl of their own - but they are meant to be displayed into other templates. my case is an image gallery with some navigators.

from a functional and design point of view, it makes sense that the navigator logic and the thumbnails be visible in the template of the gallery node (since the gallery/folder node "knows" its children, while the single image is displayed in a space of this template. But if static cache works as I think it does, I have to turn this structure backwards, and have the override template for the single image-node contain the navigator, and have the override folder for the gallery folder simply not be available for direct view, but redirect somehow to one of it's children node images.

I hope I have been clear - so, can anyone share their experience on this? and am I right in thinking so, or am I overlooking something / wrong on something?

thanks for your contributions and thoughts,

Massimiliano

Gabriel Ambuehl

Thursday 23 February 2006 6:41:19 am

This issue is pretty much a non issue when you know how static cache works [1]. It does, in fact (took me some messing with the code as per usual, but I believe in the end it boils down to this) SPIDER the site like any other spider would see it. So it sees exactly what YOU see on the site when you access it (as anonymous obviously).

If currently the links work ok, they very well should keep on doing so.

[1] If that is not correct, please excuse, it was many months ago that I played with this feature.

Visit http://triligon.org

Massimiliano Bariola

Thursday 23 February 2006 6:45:11 am

Thanks Buz, that actually seems a more sensible way of working, and it gets rid of a lot of problems! ;-)

if this is the case, I'll knock my bosses's socks off when I'll turn on that baby.

eZ debug

Timing: Jan 18 2025 15:56:57
Script start
Timing: Jan 18 2025 15:56:57
Module start 'content'
Timing: Jan 18 2025 15:56:57
Module end 'content'
Timing: Jan 18 2025 15:56:57
Script end

Main resources:

Total runtime0.1453 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0055 587.8594180.8125
Module start 'content' 0.00550.0046 768.671997.8359
Module end 'content' 0.01010.1351 866.5078529.3750
Script end 0.1452  1,395.8828 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00302.0491200.0001
Check MTime0.00120.8379200.0001
Mysql Total
Database connection0.00140.942210.0014
Mysqli_queries0.101669.90351410.0007
Looping result0.00120.83571390.0000
Template Total0.134792.710.1347
Template load0.00080.534810.0008
Template processing0.134092.199110.1340
Override
Cache load0.00050.364110.0005
Sytem overhead
Fetch class attribute can translate value0.00060.384010.0006
XML
Image XML parsing0.00020.135510.0002
General
dbfile0.00463.1537200.0002
String conversion0.00000.003330.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