Wednesday 23 March 2011 10:10:31 am
By : Marko Žmak
The eZ Comments extension is a very simple and easy to use solution if you want to setup an article commenting system quickly. But in my experience it's a bad idea to use it if you need any advanced commenting functionalities. So read further if you want to find about it...
In my experience as an eZP developer I have implemented many sites with the article commenting feature. Only one of them was implemented using the eZ Comments extension, and soon after that I abandoned this approach and went back to implementing the comments system using the eZP's content model (objects of class “Comment” as children of articles).
Actually, my experience with both solutions taught me that the main problem of eZ Comments extension is that it doesn't use the eZP content model. Several usability and conceptual problems come out of this fact:
On the other hand... First, all of these features can be implemented using the Comment class for comments. Second, there are no features of eZ Comments extension that cannot be implemented using the standard eZP content model and functionalities.
Furthermore, one feature that is pointed out as most important in eZ Comments is:
“using separate table for storing comments to improve performance”
Which sounds like a very good idea but actually it isn't. Here are some counter arguments...
The statement that putting comments in a separate table gives a valuable performance improvement doesn't really stand. Anyone that have analyzed eZP fetches deeply (I mean like on the level of MySQL EXPLAIN query) and on real usage examples will know that when fetching only objects of Article class the performance is not really much degraded by the number of comment objects on your site. The article/comment ratio is usually evenly distributed over the node tree (you won't have a category with only 10 articles and 1000 comments) with a constant order of magnitude, which is usually very low. It won't make much difference if you perform an sql query on 1000 indexed objects or 2000.
Also, there are several techniques that can allow you to have a lot of content without loosing much of performance in fecthes. For example, I have a (high traffic) site with more than 200.000 objects performing complex fetches, and their performance is pretty much the same as if there were only 2.000 objects. On the site the comments are implemented using the “Comment” class and it does not degrade performance at all.
It's all about understanding your site and using eZP wisely.
Who when and why made the decision that comments are not content?
As far as I'm concerned, comments are content because I want to be able to do with them most of the tasks I want to do with other content:
By putting comments in a separate database table you loose all this capabilities and also any other future functionality that will be implemented in eZP and it's content model.
My opinion is that the approach of implementing the comments system without using the powerful eZ content model was a bad decision and very wrong. It looks like reinventing the wheel in a shape of triangle...
The only true advantage that I found in eZ Comments it's that comes with ready made templates and allows you to setup the commenting system very quickly. But that can all be done reagardless of the implementation, right?
My suggestion would be to rewrite completely the eZ Comments extension and implement it using the eZ content model and existing eZP capabilities. And wrap it nice with all the shiny and easy to use features that already has, so that retains the same usability.
There it is. Now after I've written about comments, I'm ready to hear some comments...
Timing: | Jan 17 2025 23:53:33 |
Script start | |
Timing: | Jan 17 2025 23:53:33 |
Module start 'layout' | |
Timing: | Jan 17 2025 23:53:33 |
Module start 'content' | |
Timing: | Jan 17 2025 23:53:33 |
Module end 'content' | |
Timing: | Jan 17 2025 23:53:33 |
Script end |
Total runtime | 0.0920 sec |
Peak memory usage | 6,144.0000 KB |
Database Queries | 42 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0079 | 588.0469 | 152.6406 |
Module start 'layout' | 0.0079 | 0.0029 | 740.6875 | 39.4844 |
Module start 'content' | 0.0108 | 0.0798 | 780.1719 | 379.1484 |
Module end 'content' | 0.0906 | 0.0014 | 1,159.3203 | 19.7031 |
Script end | 0.0920 | 1,179.0234 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0034 | 3.6796 | 15 | 0.0002 |
Check MTime | 0.0013 | 1.3696 | 15 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0008 | 0.8825 | 1 | 0.0008 |
Mysqli_queries | 0.0312 | 33.9092 | 42 | 0.0007 |
Looping result | 0.0003 | 0.3578 | 40 | 0.0000 |
Template Total | 0.0554 | 60.2 | 2 | 0.0277 |
Template load | 0.0019 | 2.0910 | 2 | 0.0010 |
Template processing | 0.0535 | 58.1182 | 2 | 0.0267 |
Template load and register function | 0.0001 | 0.0935 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0006 | 0.6957 | 1 | 0.0006 |
state_identifier_array | 0.0011 | 1.2204 | 2 | 0.0006 |
Override | ||||
Cache load | 0.0017 | 1.8054 | 43 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0026 | 2.7807 | 3 | 0.0009 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0166 | 3 | 0.0000 |
General | ||||
dbfile | 0.0021 | 2.2607 | 10 | 0.0002 |
String conversion | 0.0000 | 0.0111 | 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 | ||
9 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
2 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
2 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
1 | content/datatype/view/ezxmltags/emphasize.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/emphasize.tpl | ||
3 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
1 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.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: 10 |
Time used to render debug report: 0.0002 secs