Wednesday 09 February 2011 9:05:02 am
By : Marko Žmak
The ezsi extension is a pretty good one, but there are situations where it doesn't do the job. It lacks a "fragmented" caching mechanism.
Last few days I have dealt with performance optimization of complex site with a lot of content, lots of visitors and a very high refresh rate. The site is using standard eZP caching mechanisms, view cache, cache blocks and static cache, but as the pageviews started to increase it needed more... As a first choice I tried the ezsi extension but it just couldn't do the job...
The problem is that there are pages (for example the frontpage) that have a lot of heavy parts that have to be refreshed very often, and all at the same time. This heavy parts have a complex template logic and produce heavy SQL queries. And since they all have to be refreshed very often and at the same time, the complete processing of the page tends to become very demanding.
So when the server is under heavy load, it happens that the execution of the queries often fails and sometimes the complete eZP generation of the heavy page also fails. This ends up in parts of page missing or in outputting a fatal error. So I started to look for a solution that would allow me to execute and cache this heavy parts separately.
I have investigated the possibility of solving this problem with ezsi extension combined with Apache SSI, but I came to the conclusion that it doesn't work for this case.
The problem with ezsi is that it doesn't give you the possibility of "fragmented" cache generation. When the ezsi cronjob does the si-blocks regeneration it actually calls the URL of the page where the block was generated. So the whole page is processed and if all the blocks have the same TTL (which is needed in may case), all of them are re-executed which leads back to the original problem and doesn't help at all.
The solution I came up with is:
So I did it... I've created a module that allows you to include a chosen template based of the view parameters, and without any additional processing of nodes etc. And combined with an empty page layout this gives us the possibility to execute specific parts of the code via special URLs.
So, for example an URL like this
can be setup (via an eZ template) to output the list of top rated content within last 2 days.
Then all I had to do is put URLs like this in the static cache list, put the appropriate SSI includes in my templates, and that's it. This pretty simple idea did the trick.
Not to be misunderstood, I'm not saying that ezsi extension doesn't do a good job, but it doesn't yet have the solution for the problem I described. In fact, I would be very glad if a mechanism like the one in my solution, gets implemented in ezsi.
And here's a proposal for the implementation:
This is just a basic idea and is probably not bulletproof, but I believe it's worth exploring. Any feedback, opinions and counter-ideas are appreciated.
Timing: | Jan 17 2025 23:53:39 |
Script start | |
Timing: | Jan 17 2025 23:53:39 |
Module start 'layout' | |
Timing: | Jan 17 2025 23:53:39 |
Module start 'content' | |
Timing: | Jan 17 2025 23:53:39 |
Module end 'content' | |
Timing: | Jan 17 2025 23:53:39 |
Script end |
Total runtime | 0.0839 sec |
Peak memory usage | 6,144.0000 KB |
Database Queries | 43 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0057 | 591.5391 | 152.6250 |
Module start 'layout' | 0.0057 | 0.0022 | 744.1641 | 39.4531 |
Module start 'content' | 0.0079 | 0.0742 | 783.6172 | 378.1641 |
Module end 'content' | 0.0821 | 0.0017 | 1,161.7813 | 19.7031 |
Script end | 0.0839 | 1,181.4844 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0037 | 4.4243 | 15 | 0.0002 |
Check MTime | 0.0015 | 1.7748 | 15 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0007 | 0.8497 | 1 | 0.0007 |
Mysqli_queries | 0.0289 | 34.4853 | 43 | 0.0007 |
Looping result | 0.0003 | 0.3189 | 41 | 0.0000 |
Template Total | 0.0511 | 60.9 | 2 | 0.0255 |
Template load | 0.0026 | 3.0837 | 2 | 0.0013 |
Template processing | 0.0485 | 57.7906 | 2 | 0.0242 |
Template load and register function | 0.0001 | 0.1333 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0004 | 0.5294 | 1 | 0.0004 |
state_identifier_array | 0.0010 | 1.1629 | 2 | 0.0005 |
Override | ||||
Cache load | 0.0022 | 2.5705 | 39 | 0.0001 |
Sytem overhead | ||||
Fetch class attribute name | 0.0025 | 3.0261 | 3 | 0.0008 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0128 | 3 | 0.0000 |
General | ||||
dbfile | 0.0015 | 1.7611 | 10 | 0.0001 |
String conversion | 0.0000 | 0.0094 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | blog_entry/full.tpl | extension/community_design/design/suncana/override/templates/blog_entry/full.tpl | ||
2 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
2 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
6 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
5 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
5 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
1 | content/datatype/view/ezkeyword.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezkeyword.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 23 Number of unique templates used: 8 |
Time used to render debug report: 0.0002 secs