Forums / Setup & design / ViewCaching per user

ViewCaching per user

Author Message

Franck Grenier

Wednesday 20 April 2011 7:29:56 am

Hello,

I'm having questions about viewCaching.

I work on an Intranet with almost 3000 users. ViewCaching is disabled. When I enabled it, caches are not regenerated and users do not see the most recent data.

First question : Should I really enable ViewCaching ?

Second question : If I enable ViewCaching with "pr_user" parameter, I guess my site could generate a very very large number of caches. Is it right ?

Developer at Open Wide

Marko Žmak

Wednesday 20 April 2011 11:46:04 pm

Yes, you should really enable ViewCaching. Usually you should disable it for some complex pages and use template cache-block on thoose pages instead.

As you can see in the docs:

  • http://doc.ez.no/eZ-Publish/Technical-manual/4.x/Features/View-caching

view caching is not generated per user, but rather per set of permissions/preferences:

Please note that eZ Publish creates multiple view caches for the nodes based on roles and user preferences. This means that for example different users (who are logged in, with different permissions/preferences) will be served different caches while anonymous users and users with the same type of permissions/preferences will be served the same file. In other words, when view caching is on, the "view" view of the "content" module will only be run if the system is unable to locate a view-cached version of the result - otherwise a cached version will be inserted in the pagelayout. Please note that the pagelayout itself is not cached by default.

As for your problem, there can be several reason for it so you should investigate it a little bit further and give us some more info.

For example, the cache dir of your frontend siteaccess should be the same as the cache dir for the admin siteacces. Also, view cache for a node is regenerated only when the node is changed and published. Furthermore, the parts of the page that are in pagelayout.tpl do not use view cache. And so on...

--
Nothing is impossible. Not if you can imagine it!

Hubert Farnsworth

Bertrand Dunogier

Thursday 21 April 2011 5:17:59 am

Sorry Marko but Franck is right: if you enable the ViewCacheTweak pr_user, ViewCaching will be generated per user. Franck, you can indeed try enabling it, and see how it performs. But it will indeed generate lots of cache files, as a combinatory of user + preferences if you have any. Cache clearing can then be quite heavy. But it is worth a try.

pr_user or not, as Marko said, it should get cleared when the related content is updated, as simple as that. Investigate based on what Marko told you, and you should figure it out. Ask again here if you need help.

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Marko Žmak

Thursday 21 April 2011 6:47:05 am

"

Sorry Marko but Franck is right: if you enable the ViewCacheTweak pr_user, ViewCaching will be generated per user. Franck, you can indeed try enabling it, and see how it performs. But it will indeed generate lots of cache files, as a combinatory of user + preferences if you have any. Cache clearing can then be quite heavy. But it is worth a try.

"

Yes, sorry I didn't notice that part. But this proves that ViewCacheTweak should be documented in the official docs (and not only in Serwatka's hidden gems).

--
Nothing is impossible. Not if you can imagine it!

Hubert Farnsworth

Franck Grenier

Thursday 21 April 2011 7:24:53 am

Ok, I will try this. Or maybe not if i don't have time...

And don't mind eZ Publish ! You are well documented. ;-)

Developer at Open Wide

Bertrand Dunogier

Thursday 21 April 2011 8:22:32 am

"

Yes, sorry I didn't notice that part. But this proves that ViewCacheTweak should be documented in the official docs (and not only in Serwatka's hidden gems).

"

True, true... maybe you could file a documentation issue ? Our doc manager is quite responsive, we keep him well fed !

"

And don't mind eZ Publish ! You are well documented.

"

Thanks ! But you're being overly kind here ;-)

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Marko Žmak

Saturday 23 April 2011 2:21:51 am

"
"

Yes, sorry I didn't notice that part. But this proves that ViewCacheTweak should be documented in the official docs (and not only in Serwatka's hidden gems).

"

True, true... maybe you could file a documentation issue ? Our doc manager is quite responsive, we keep him well fed !

"

OK, here it is:

  • http://issues.ez.no/IssueView.php?Id=18277&activeItem=1

--
Nothing is impossible. Not if you can imagine it!

Hubert Farnsworth

eZ debug

Timing: Jan 17 2025 22:50:51
Script start
Timing: Jan 17 2025 22:50:51
Module start 'content'
Timing: Jan 17 2025 22:50:52
Module end 'content'
Timing: Jan 17 2025 22:50:52
Script end

Main resources:

Total runtime0.6996 sec
Peak memory usage4,096.0000 KB
Database Queries208

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0052 588.8203180.8516
Module start 'content' 0.00520.5796 769.6719653.7734
Module end 'content' 0.58480.1147 1,423.4453345.0703
Script end 0.6995  1,768.5156 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00380.5366210.0002
Check MTime0.00140.2050210.0001
Mysql Total
Database connection0.00080.120910.0008
Mysqli_queries0.619088.47702080.0030
Looping result0.00200.28412060.0000
Template Total0.678497.020.3392
Template load0.00210.293920.0010
Template processing0.676396.666620.3381
Template load and register function0.00020.030610.0002
states
state_id_array0.00070.105610.0007
state_identifier_array0.00070.103920.0004
Override
Cache load0.00190.2716520.0000
Sytem overhead
Fetch class attribute can translate value0.00120.164840.0003
Fetch class attribute name0.00100.147390.0001
XML
Image XML parsing0.00160.234440.0004
class_abstraction
Instantiating content class attribute0.00000.0038120.0000
General
dbfile0.00290.4104350.0001
String conversion0.00000.000730.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
7content/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
5content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
2content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
3content/datatype/view/ezxmltags/emphasize.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/emphasize.tplEdit templateOverride template
5content/datatype/view/ezxmltags/quote.tpldatatype/ezxmltext/quote.tplextension/ezwebin/design/ezwebin/override/templates/datatype/ezxmltext/quote.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: 9

Time used to render debug report: 0.0002 secs