Performence issues

Author Message

Pierre Tissot

Thursday 18 October 2007 2:10:44 am

Hello,

My site is under performence problems, I have all the cache settings set:

[ContentSettings]
ViewCaching=enabled
PreViewCache=enabled
CachedViewModes=full;line;sitemap;pdf

[TemplateSettings]
TemplateCache=enabled
TemplateCompile=enabled
TemplateOptimization=enabled

I have put several cache-block in my page layout that expiry in 1 day.

the only thing that is not under cache-block (obviously) is:

{$module_result.content}

But in some of the view templates, the slowest ones, I put the

{set-block scope=root variable=cache_ttl}86400{/set-block}

My site once in under the cache is very fast (0.2 seconds), when not we can wait 5-30 seconds to retrieve a page

Example:

Timing points:

Checkpoint	Elapsed	Rel. Elapsed	Memory	Rel. Memory
Module start 'content'	0.0000 sec	2.7060 sec	0.0000KB	0.0000KB
Module end 'content'	2.7060 sec	2.7119 sec	0.0000KB	0.0000KB
End	5.4179 sec	 	0.0000KB	0.0000KB
Total runtime:	5.4427 sec	

Time accumulators:
 Accumulator	 Elapsed	 Percent	 Count	 Average
ini_load				
Load cache	0.0429 sec	0.7802%	16	0.0027 sec
FindInputFiles	0.0370 sec	0.6720%	16	0.0023 sec

TS translator				
TS init	0.0061 sec	0.1102%	4	0.0015 sec
TS cache load	0.0036 sec	0.0660%	4	0.0009 sec
TS context load	0.0025 sec	0.0452%	4	0.0006 sec
Template Total	5.3781 sec	97.8%	3	1.7927 sec
Template load	0.0163 sec	0.2963%	3	0.0054 sec
Template processing	5.3612 sec	97.4681%	3	1.7871 sec
Template load and register function	0.0004 sec	0.0065%	1	0.0004 sec

override				
Cache load	0.0398 sec	0.7231%	32	0.0012 sec
Matching rules	0.0063 sec	0.1146%	10	0.0006 sec
class_abstraction				
Instantiating content class attribute	0.0625 sec	1.1368%	176	0.0004 sec
Sytem overhead				
Fetch class attribute can translate value	0.0135 sec	0.2452%	13	0.0010 sec
Fetch class attribute name	0.0039 sec	0.0705%	3	0.0013 sec

XML				
Image XML parsing	0.1925 sec	3.5003%	19	0.0101 sec

General				
dbfile	0.0156 sec	0.2833%	175	0.0001 sec
String conversion	0.0011 sec	0.0199%	23	0.0000 sec
Total script time:	5.5004 sec	

Regardless all this after 2 hours the view cache is set invalid and again 5 seconds to build it. Can someone tell me what it's going on? Can I set this 2 hours time to 24 hours (I have a crawler that feeds the cache at nigth) ?

Thx in advance
PiR

André R.

Thursday 18 October 2007 3:25:27 am

Regardless all this after 2 hours the view cache is set invalid and again 5 seconds to build it. Can someone tell me what it's going on? Can I set this 2 hours time to 24 hours (I have a crawler that feeds the cache at night) ?

Viewcache is normally not invalidated by time, so this is probably your cache blocks invalidating (they invalidate every 2 hour unless you specify something else).
To invalidate view cache every 2 hour you would have something like this in your node template:

{set-block scope=root variable=cache_ttl}7200{/set-block}

So you should look into tweaking your cache blocks, remember to not have to many of them, evaluate if you can use subtree_expiry or even ignore_content_expiry to reduce cache invalidation as much as possible. And specify expiry time so that they survive more then 2 hours.

As for performance when stuff is uncached, this is hard to help you with without looking at the code. But rule of thumb is:
* Template code is slow, 10 lines of template code could result in 1000 lines of compiled php code. So rethink any site logic that is controlled by templates and take advantage of the permission / override / content class system if you can.
If not, rewrite any heavy logic to a custom template operator. The php api of eZ publish is far richer then the stuff you have access to in templates, so it is likely that you can do things more efficiently there as well.

* Pay close attention to how many database calls that are made during a uncached request. Any page with over 200 sql calls pr request should be looked at.

* Consider upgrading to eZ Publish 4.0 as soon as it's gold, it will normally give you a performance improvement from 50-200% over what you have, and in some edge case even more.

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 19:29:57
Script start
Timing: Jan 18 2025 19:29:57
Module start 'layout'
Timing: Jan 18 2025 19:29:57
Module start 'content'
Timing: Jan 18 2025 19:29:57
Module end 'content'
Timing: Jan 18 2025 19:29:57
Script end

Main resources:

Total runtime0.0153 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0051 589.6953152.6094
Module start 'layout' 0.00510.0026 742.304739.4297
Module start 'content' 0.00770.0054 781.734493.4297
Module end 'content' 0.01310.0021 875.164134.3047
Script end 0.0152  909.4688 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002516.7026140.0002
Check MTime0.00117.4249140.0001
Mysql Total
Database connection0.00084.927010.0008
Mysqli_queries0.002114.046930.0007
Looping result0.00000.092210.0000
Template Total0.001710.910.0017
Template load0.00106.315810.0010
Template processing0.00074.513110.0007
Override
Cache load0.00064.239710.0006
General
dbfile0.00031.874680.0000
String conversion0.00000.048440.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_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