Forums / Developer / How the cache works with cache blocks (technical)

How the cache works with cache blocks (technical)

Author Message

Xavier Dutoit

Wednesday 13 September 2006 8:02:44 am

Hi,

It might or might not be related to the mysterious edit button that is displays on the wrong posts in ez forum. http://ez.no/community/forum/general/do_you_see_the_edit_button

I have a page layout with two differents part (say middle and left column) that are dynamic (ie differs from node to node).

in the pagelayout, I've got something like that :


main part

{$module_result.content}

<hr/>
other part

{cache-block keys=array($uri_string,$current_user.login)}
{section show=is_set($#extra)}
{$#extra}
{section-else}
generic part
{/section}
{/cache-block}

Then in the overrided full.tpl :

Bla bla in the main part

{set-block variable="extra" scope="global"}
bla bla in the other part
{/set-block}

The idea is that each template can set a different other part #extra for each user.

Unfortunately, it doesn't always work. If you change from one user to another and display the same page, it sometimes doesn't display the other part. Then, if you clear all the caches, it displays the correct one again, but other users might get the wrong other part, on that node or another.

It has different reactions if the template is complied or isn't, both with problem. It is very hard to reproduce, even by using several computers.

The only idea I have is that sometimes, the cache system decides that either the $module_result.content
or the extra block is already calculated and in cache and doesn't keep the two parts in sync.

Do you have any idea ? I'm seriously in the dark and that drives me nuts.

Am I wrong assuming that module.content is calculated once for every user ? In other word, that it won't use a cache of a content generated for a user won't be used for another one ?

X+

http://www.sydesy.com

Paul Forsyth

Wednesday 13 September 2006 8:41:46 am

Maybe the view cache of the full.tpl override is interfering? What if you ttl 0 that file?

Paul

Xavier Dutoit

Wednesday 13 September 2006 9:06:14 am

Hi Paul and thanks for the suggestion.

I'll try to change that. The problem is as I can't find a predictable way of having the two parts out of sync, I can only try to login/out with a different user until something happend. If it doesn't, it won't mean it won't happend later.

Anyway, the ttl=0 isn't going to be very good for the perf ;)

X+

P.S. Is there a way to debug the cache ? I would like to display informations about what is in the cache (file name?) and what isn't. How do you do that ?

http://www.sydesy.com

Xavier Dutoit

Friday 15 September 2006 11:17:32 pm

Hi,

Found one of the problems: the TTL of the cache isn't set, so that's two hours per default. After two hours, the cache isn't cleared, but the variable isn't calculated when the cache is recalculated.

I'll try to play with expiry=expiry ignore_content_expiry or subtree_expiry=subtree_expiry

That's going to be great fun to debug...

X+

http://www.sydesy.com

Paul Forsyth

Sunday 17 September 2006 8:29:17 am

You could ttl=0 the whole template but then cache-block everything within according to your needs with appropriate keys.

Not sure if your last comment suggests a bug or not.

Hope your having fun!

P

Xavier Dutoit

Sunday 17 September 2006 3:01:59 pm

Hi,

I don't think that's a bug, just hard to make it work.

Taking about you suggestion or ttling the content and using cache, I'm not sure they are any options to do reproduce the same result.

Eg: full.tpl

{set-block scope=root variable=cache_ttl}0{/set-block}
{cache-block
key=???
expiry=0
subtree_expiry=$node.url_alias}

1) I don't know what's the key to put to have the same one that the standard content.
It looks like it's somehow dependent on the user (eg an admin on the forum here and a regular user aren't going to have the same thing), but it isn't recalculated for every user (can be proven wrong, but I think that would explain the bug of the misterious edit button on the wrong posts in the forum on ez);.

2) The cache is going to be cleared on any item published under it, no matter how deep it is. The standard behaviour is to limit that to the node and its children (deep=1).

Am I wrong ? I never found any definitive descriptions on the rules of the content cache (what are the rules to decide if the cache is used or if it's recalculated) and it behaves differently when the template is compiled or isn't.

Has someone seen something like that ?

X+

http://www.sydesy.com

eZ debug

Timing: Jan 18 2025 14:58:31
Script start
Timing: Jan 18 2025 14:58:31
Module start 'content'
Timing: Jan 18 2025 14:58:32
Module end 'content'
Timing: Jan 18 2025 14:58:32
Script end

Main resources:

Total runtime1.3527 sec
Peak memory usage4,096.0000 KB
Database Queries203

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0069 587.8438180.8125
Module start 'content' 0.00691.2051 768.6563583.2266
Module end 'content' 1.21190.1407 1,351.8828341.3672
Script end 1.3526  1,693.2500 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00410.3039210.0002
Check MTime0.00160.1163210.0001
Mysql Total
Database connection0.00170.128710.0017
Mysqli_queries1.271493.98922030.0063
Looping result0.00230.16682010.0000
Template Total1.321297.720.6606
Template load0.00200.148420.0010
Template processing1.319197.518520.6596
Template load and register function0.00010.007110.0001
states
state_id_array0.00080.055510.0008
state_identifier_array0.00090.066920.0005
Override
Cache load0.00170.1273590.0000
Sytem overhead
Fetch class attribute can translate value0.00130.094730.0004
Fetch class attribute name0.00080.062270.0001
XML
Image XML parsing0.00080.062630.0003
class_abstraction
Instantiating content class attribute0.00000.0013100.0000
General
dbfile0.00360.2636270.0001
String conversion0.00000.000430.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
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
6content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
11content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
3content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 28
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs