Forums / General / cache-block around $module_result.content

cache-block around $module_result.content

Author Message

Michael Zeidler

Monday 13 September 2004 2:53:19 am

Hi,

Please explain me, why its not a good idea to add a cache-block around {$module_result.content}, as I have read somewhere here in this forum. Unfortunately i cant find this appropriate topic anymore.
I cant see any disadvantages using cache-block this way:

{cache-block expiry=0 keys=array($uri_string,$current_user.role_id_list|implode(','))}
  {$module_result.content}
{/cache-block}

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

Edward Eliot

Monday 13 September 2004 4:09:53 am

I guess it depends on how much control you want over the caching. If you only need to cache certain parts of the page then this implementation isn't going to be much good. If you are happy caching the whole page then it's fine.

Michael Zeidler

Monday 13 September 2004 4:30:17 am

What parts on the website you dont want to be cached? IMHO I would prefer caching rather than any php and database query execution, cause outputting a text file is faster than that. Ok you might distinguish parts which only executes php functions like echo() and on the other hand php functions accessing backends, like DB, LDAP, or processing transformations of XML.
So {$module_result.content} involves at least database queries, isnt that a reason to cache it.

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

Paul Forsyth

Monday 13 September 2004 5:01:29 am

I think you are missing what eZ publish is about. {$module_result.content} returns the results from your current view, but that view may itself be made up of many other templates, some of which may be dynamic and should not be cached.

Sometimes your headers,footers, menu etc are in that view, and not the main pagelayout. It all depends on your design and what you need. eZ publish gives you this flexiblity.

You could put everything in pagelayout, this could be what your design requires. I know from my own experience that it varies.

If your content rarely changes then the cache block around the content would help.

paul

Michael Zeidler

Tuesday 14 September 2004 1:15:02 am

Yes of course {$module_result.content} returns the current view which is generated by the requested module to do so. Generally database queries are involved with that, dynamic elements are excluded. So for me a good reason to cache it.

> but that view may itself be made up of many other templates,
> some of which may be dynamic and should not be cached.

Do you mean templates which includes for instance the print out of the current date or things like that? Yes, this wouldnt make any sense to cache it. So it would be good to put these things into the pagelayout.tpl and not to use any cache-block for it. But of course it depends on the flavor where in the design to do the printing out of dynamic contents, as you already have said.
But from the point of view that the content ({$module_result.content}) is altered only by an publishing event the cache-block solution would fit in this case.

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

Ole Morten Halvorsen

Tuesday 14 September 2004 1:57:07 am

Cupic,

The content module already has caching (called ViewCache), so putting a cache-block around would cache an already cached page. Also, if you put cache-blocks around $module_result.content you will mess up modules which needs to be dynamic like /user/login. The login template will not be able to display warnings if the user types wrong password for example.

In conclusion, you should not put cache-blocks around $module_result.content (you will experience weird behaviour) and you dont need to as the content module has ViewCache.

Ole M.

Senior Software Engineer - Vision with Technology

http://www.visionwt.com
http://www.omh.cc
http://www.twitter.com/omh

eZ Certified Developer
http://ez.no/certification/verify/358441
http://ez.no/certification/verify/272578

Michael Zeidler

Tuesday 14 September 2004 6:40:04 am

Ok, thanks for the precious info. But as u might have seen I want to provoke that the cache-block wont be expired, because every two hours the cache will be cleared totally. Is the behavior of the view cache the same? See this posting http://ez.no/community/forum/general/how_to_switch_off_clear_cache_interval.
Some infos to ViewCache http://ez.no/community/forum/developer/viewcaching_and_cache_block_when_to_use

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

Michael Zeidler

Tuesday 14 September 2004 7:27:13 am

another example where the cache-block around $module_result.content fails ist the search. the search shouldnt be cached ;).

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

Ole Morten Halvorsen

Friday 17 September 2004 2:45:06 am

Cupic,

If you set expiry=0 the cache-block should never be expired unless something is published. If it doesn't then please file a bug report. If you don't want the cache-block to expire on publish use ignore_content_expiry.

Read more about cache-blocks here:
http://ez.no/ez_publish/documentation/development/kernel/cache_block_optimization

Ole M.

Senior Software Engineer - Vision with Technology

http://www.visionwt.com
http://www.omh.cc
http://www.twitter.com/omh

eZ Certified Developer
http://ez.no/certification/verify/358441
http://ez.no/certification/verify/272578

Michael Zeidler

Friday 17 September 2004 5:19:06 am

Well, yes of course expiry=0 works very well. But the main goal is to do a work around the clear cache interval, which is set to two hours. Unfortunately there is no configuration variable to alter this value, it seems to be hard coded in the eztemplate engine(3.4.1). This is the reason why i want the content to be cached eternaly unless a publish action was triggered. Whats the reason for clearing the cache every two hours?
Please take a look on this: http://ez.no/community/forum/general/how_to_switch_off_clear_cache_interval

-------------------------------------------------------------------------------------------
join #ezpublish on irc.freenode.org

eZ debug

Timing: Jan 19 2025 03:37:18
Script start
Timing: Jan 19 2025 03:37:18
Module start 'content'
Timing: Jan 19 2025 03:37:18
Module end 'content'
Timing: Jan 19 2025 03:37:18
Script end

Main resources:

Total runtime0.7478 sec
Peak memory usage4,096.0000 KB
Database Queries219

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0069 589.0703180.8203
Module start 'content' 0.00690.6262 769.8906699.4063
Module end 'content' 0.63310.1146 1,469.2969348.4531
Script end 0.7477  1,817.7500 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00390.5230210.0002
Check MTime0.00140.1853210.0001
Mysql Total
Database connection0.00130.179110.0013
Mysqli_queries0.655887.70892190.0030
Looping result0.00210.28612170.0000
Template Total0.716595.820.3583
Template load0.00220.300420.0011
Template processing0.714395.521720.3571
Template load and register function0.00020.026010.0002
states
state_id_array0.00100.132910.0010
state_identifier_array0.00110.146620.0005
Override
Cache load0.00190.2548500.0000
Sytem overhead
Fetch class attribute can translate value0.00130.174750.0003
Fetch class attribute name0.00110.1463110.0001
XML
Image XML parsing0.00280.369550.0006
class_abstraction
Instantiating content class attribute0.00000.0039160.0000
General
dbfile0.00480.6452270.0002
String conversion0.00000.000830.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
6content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
10content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
14content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 40
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs