Forums / Developer / Nearly Impossible: Caching of admin interface

Nearly Impossible: Caching of admin interface

Author Message

Georg Franz

Thursday 22 December 2005 5:16:45 am

Hi folks,

I've noticed that there are no active cache-blocks in the current admin pagelayout.tpl.

Problem: 500+ sql queries at 1 page request, over and over again, cause not much is cached.

I tried to add some cache-blocks and noticed that I can't use them because they prevent that the site works properly. (Example: All urls are changing if you go to the "browse mode" ...)

I've learned: To cache the admin site properly you need a lot of time to rewrite some templates ... (And I don't like the idea rewriting / overwriting admin templates ...)

So, my questions:

a) Has somebody done this work already?
b) Is it really a good idea to add cache blocks? (Over-use of cache?)
c) Is there a simpler/other way doing this job?

Best wishes,
Georg.

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

Gabriel Ambuehl

Thursday 22 December 2005 6:32:18 am

Caching seems to be pretty efficient to me already. I see page load times of less than half a second when view cache is on?

There are some issues with BIG sites though but thats because of the complete tree loading each time and can (partly at least) be resolved by using one of the AJAX menus.

Visit http://triligon.org

Georg Franz

Thursday 22 December 2005 6:52:31 am

Hi Gabriel,

I am already using the Ajax menu at some sites ... it helps a lot, but there are also 300-500 queries / page request though ...

Best wishes,
Georg.

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

Paul Forsyth

Thursday 22 December 2005 7:34:26 am

I've cut down the admin a little which actually gives some screen space back to the user. The admin runs will almost everything on but you rarely need this.

Paul

Xavier Dutoit

Thursday 22 December 2005 7:34:38 am

Hi,

How do you get 500 queries per page ? Is that the number on the debug output ?

On all the pages once they are compiled ?

I'm quite surprised by this number. Could you detail so I can compare with one of my install ?

X+

http://www.sydesy.com

Georg Franz

Thursday 22 December 2005 10:28:59 am

Hi Paul,
hi Xavier,

@ Paul: Good idea, i will do something similar.

@ Xavier:
All caches are turned on, template compiling too. 500 queries happens at 3 of my sites which have more then 2000 pages content, one site has over 10.000 pages. Most of the queries comes from the menu. You can't cache the menu easily because of the role system and the changing links ("normal"/"browse mode" ...) And there are the individual settings for each user (list amount, bookmarks etc.) ... I think ez removed the cache blocks at the admin site because of a possible "caching overkill" (too much cache files ...)

If I use a simple cache-block around the menu, there are around 100-200 queries left - uncached. (Depends on the page of course.) In my eyes it should be possible to cut down the query amount to 20-50 on a cached page.

Best wishes,
Georg.

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

Gabriel Ambuehl

Thursday 22 December 2005 10:32:35 am

But if you were to use some AJAX menu, it shouldn't fetch very much unless you've got a big part of the tree open, no?

I would think that wrapping the menu in a cache-block that depends on the UID would work quite well.

Visit http://triligon.org

Georg Franz

Thursday 22 December 2005 10:46:26 am

Hi Gabriel,

500 queries even with the Ajax menu. (I wouldn't believe this first either, but i checked the debug output ...)

The problem at the menu caching:
-) You need a unique menu for each user
-) You need to check the settings of the user
-) You need a menu for "normal links" and for "browsing mode" (probably even more)

All in all: The user has too much "individual possibilities". I think the best way is to reduce the features as Paul suggested.

Best wishes,
Georg.

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

Paul Forsyth

Thursday 22 December 2005 3:49:49 pm

I wonder if its then wise to simply cache per user and hope that the extra filespace required is ok. But then you hit regeneration issues which simply wont scale with multiple users.... grrr.

I recently added role support to the ezodcsm extension for menu popups, which i committed to pubsvn. This will increase the sql requests per node because of the permission checks in the templates but perhaps after caching it may help. With such checks i can restrict what the popup menu contains.

I use the popup menu in other areas to help restrict functionality. For example on the big class icon i have a setting to hide or show the window controls (Relations, Locations, Translations...). By default they are off. If the user doesnt have permissions they dont see the option.

To be frank the admin needs to be customisable per user per role. If im editor i dont want to see webshops, etc.

If i may diverge, another thread discusses this type of optimisation:

http://ez.no/community/forum/general/ez_speed_optimisation_faq

Is there a way to combine the findings from this thread to that one? Everyone of us hits these problems time and time again.

Paul

Georg Franz

Friday 23 December 2005 3:46:01 am

Hi Paul,

yep, my fear is that too much caching will bring down the server at the cache regeneration process. (We've discussed similar topics already some time ago.)

In my experience, there are mostly 3 types of admin users:
-) The editor - He only need a quick tree menu to navigate. He is creating / editing / deleting content.
-) The chief editor: Sometimes he moves content. He could need e.g. the popup menu functions.
-) The admin: He needs the complete functionality of ez. Probably he is the only one who uses them too.

So in many cases it's not necerssary to give a normal editor admin access. I made "edit" templates for the normal editor on the user site and provide "new/edit/delete" buttons. The biggest advantage: You dont have to teach the editors a lot, cause it's very simple.

---------------

Optimation Forum:

Paul, you are right, the "speed up" topic is coming over and over again. Maybe its a good idea to made a own forum for this topic and move the belonging postings there?

Best wishes,
Georg.

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

eZ debug

Timing: Jan 18 2025 22:31:18
Script start
Timing: Jan 18 2025 22:31:18
Module start 'content'
Timing: Jan 18 2025 22:31:19
Module end 'content'
Timing: Jan 18 2025 22:31:20
Script end

Main resources:

Total runtime1.2875 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.0073 588.9609180.8125
Module start 'content' 0.00731.0946 769.7734705.1016
Module end 'content' 1.10190.1855 1,474.8750348.4297
Script end 1.2874  1,823.3047 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00460.3587210.0002
Check MTime0.00150.1159210.0001
Mysql Total
Database connection0.00070.054910.0007
Mysqli_queries1.186692.16852190.0054
Looping result0.00270.20802170.0000
Template Total1.248297.020.6241
Template load0.00220.168420.0011
Template processing1.246096.783820.6230
Template load and register function0.00010.009010.0001
states
state_id_array0.00170.133810.0017
state_identifier_array0.00190.148320.0010
Override
Cache load0.00190.1504710.0000
Sytem overhead
Fetch class attribute can translate value0.00180.138450.0004
Fetch class attribute name0.00170.1292120.0001
XML
Image XML parsing0.00140.106450.0003
class_abstraction
Instantiating content class attribute0.00000.0021160.0000
General
dbfile0.00410.3209330.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
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
5content/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: 37
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs