Blogs / Marko Zmak / eZPublish vs. Drupal

eZPublish vs. Drupal

Monday 14 March 2011 11:26:12 am

  • Currently 5 out of 5 Stars.
  • 1
  • 2
  • 3
  • 4
  • 5

By : Marko Žmak

I have encountered a big deal of discussions abut eZP vs. Drupal, all of them stating different facts and opinions. So I hope this will shed some light on the topic...

Note that this are my own opinions and do not necessarily reflect the opinions of the eZ crew of eZ Community.

While planning a news portal project I had a discussion with two web developers about eZ Publish vs. Drupal. The goal of discussion was to determine which CMS to use as a platform for web development, not only for this portal, but also for future projects (big, small and medium). Besides as a CMS, the chosen platform would have been used also as a web application framework for developing custom web solutions and modules when needed. To sum it up, this decision was to determine our future cooperation and team development.

The two developers were cheering for Drupal and their main argument (which later came out to be the only one) was this article:

I was of course cheering for eZP, but I decided to enter this matter open minded (as much as I can), so I got myself a Drupal installation and started investigating.

I didn't look for "shiny" pieces and "wow it's got this gadget" stuff but I rather dived deep into the concept and structure of Drupal and compared it with eZP.

The conclusion was a big mail to the two developers so I'm rewriting it here completely as it was written.

***************************************************************************

The result of my two day Drupal vs. EZP analysis is the following...

1) Code quality

Drupal:
Awful! Code junk. OK, it has some good parts, but altogether non systematic and without any clear rules and order. It reminds a lot of Cowboy coding (here is a better definition than one on wikipedia: http://c2.com/cgi/wiki?CowboyCoding). For example, I took a look at the forum module code and there are absolutely no DB safe transactions, commits, ecc.

It doesn't have any abstraction layer. And don't you even dare to mention me this http://api.drupal.org/api/group/database/7 as an abstraction layer. By the way, look also at the example in the “Template system” chapter of this mail.

It's not object oriented! OK, the Drupal crew has a super nice explanation why this is good. Great! And all this modern web frameworks are of course wrong...

Furthermore, I personally believe (and also most of code developers I know) that the discussion object oriented vs. procedural in the context of web applications has no sense. Most of the web applications come down to manipulating resources through 4 HTTP verbs (GET, POST, PUT, DELETE). Resources naturally map to objects. Everything in web applications, except maybe helper functions for generating HTML and JS, naturally maps to objects. It seems to me that most intelligent procedural implementations will actually end up on objects. If you have a bunch of procedure calls which receive some “structs” or similar data structures and pass them around, effectively this is object oriented programming.

eZ:

Hi-class object programming model with great concepts and code. It has several abstraction layers and every single one of them can be used. I could talk and talk about it, but instead take a look for yourself:

Besides being object oriented it has a tendency to the HMVC pattern, the same tendency that most of the today known web application frameworks show.

2) Template system

EDIT: Later on I found out some more fresh info so before reading this chapter see this comment:

http://share.ez.no/forums/discussions/ezpublish-vs.-drupal/comment66630

Drupal has a regular PHP templating system, which can sound good, but my opinion is that this produces more chaos and damage than gains. We could enter a discussion about this topic, but instead I'll give an example...

In Drupal, to fetch 10 nodes you have to write this:

<?php

$result = db_query_range('SELECT n.nid, n.title, n.created FROM {node}',array(), 0, 10);

?>

and in eZ this:

{def $nodes=fetch(content, tree, hash(parent_node, 2, limit, 10) )}

But, bear in mind that this Drupal call only gets you the id, title and creation date, and for getting the actual content you have to do joins or make several query calls. In eZP all of this is contained within this same line of code.

The criticism that a CMS's own template language degrades performance doesn't stand, because eZP has a template compilation system which compiles all the templates into PHP files and executes this files. The refreshing of this PHP compiled files does not represent a problem.

Furthermore, Drupal seems more like oriented to theming existing modules, and eZP more to custom templates. It's enough to say that Drupal in it's core installation has a folder called “themes”.

3) Database structure

Drupal:

It doesn't have one. OK, it has one but what is it? It comes down to basic tables for node storage and core features. Almost every module I have looked at, creates some new tables in the database. Besides of getting a vast database, who can guarantee the quality of this tables and what about database integrity? And what about sharing data between modules?


Furthermore, this concept of DB scheme produces questions like this:

OK, the guy that asked that is pretty much an amateur that doesn't know what he's dealing with, but the fact that such questions even exist means that for adding any custom solution you have to think about creating new SQL tables and planning their structure.

In eZP you don't have such worries. Most of custom needs can be done through existing DB schema or some abstraction layer. If it's necessary, in eZP you can easily create and modify DB schema from XML definitions. OK, Drupal also has something like this, but is it powerful as this:

eZ:
With the concept of nodes, objects and ready made attributes, the need for creating new SQL tables for new functionality is eliminated.

And another interesting detail, on www.whitehouse.gov, the whitehouse web development team made a module that simulates eZP node tree structure. It means that there was a natural need for such a thing.

4) Framework/library

Drupal doesn't have it. Period.
eZP has eZComponents. Period.

5) Performance

We exchanged a lot of opinions about this one, and we all know what is the biggest worry (the article about the Swiss newspaper), but I'm still convinced that eZP can be setup and configured to work as efficiently as Drupal. I already did it on two big projects.

6) General impression

I cannot get rid of the impression that the whole Drupal system resembles very much to Joomla!

Besides that, the overall eZP development and ideology look far more serious and professional.

Of course, this is my opinions and I cannot say nothing more than expressing my personal feeling.

7) Comparison conclusion

It looks to me like we are comparing DOS with Windows.

Not to be misunderstood, in my lifetime I have done the following things in DOS:

  • used LAN and sent messages through Windows Messenger
  • played 3D games
  • connected with FTP and SSH to remote machines (and used this actively)
  • coded in PHP
  • surfed the web with full HTML browser
  • made a realtme version of the Scorch game
  • used point&click GUI (not only Windows 3.11, but also others)
  • used multitasking
  • watched pictures and video (real video not the Aalib stuff)
  • used instant messaging
  • read and sent mails
  • created programs for computations in mathematics and physics
  • worked with databases
  • listened to and programmed music

So, DOS can do everything what Windows can, and it can do it faster!

P.S. If someone is interested in how all this things can be accomplished in DOS, feel free to contact me. There are some things I still remember...

***************************************************************************

NOTES:

1) The result of sending this mail was...

The two developers never responded with counterarguments and they didn't become a part of the team for the project. I have chosen eZ Publish and started a fresh team of new young eZP developers.

2) Everything in this text is completely my own personal opinion, based on my experience as a web developer and “intuitive feeling”. If anyone disagrees with me or is offended by something I wrote, feel free to react.

Blog Post Discussion

eZPublish vs. Drupal

eZ debug

Timing: Jan 17 2025 21:09:11
Script start
Timing: Jan 17 2025 21:09:11
Module start 'content'
Timing: Jan 17 2025 21:09:11
Module end 'content'
Timing: Jan 17 2025 21:09:11
Script end

Main resources:

Total runtime0.2444 sec
Peak memory usage6,144.0000 KB
Database Queries186

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0062 595.9453180.8516
Module start 'content' 0.00620.1170 776.7969499.5391
Module end 'content' 0.12320.1211 1,276.3359416.8047
Script end 0.2444  1,693.1406 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00391.6059210.0002
Check MTime0.00140.5799210.0001
Mysql Total
Database connection0.00080.312910.0008
Mysqli_queries0.128952.72581860.0007
Looping result0.00200.80801840.0000
Template Total0.219089.620.1095
Template load0.00180.753720.0009
Template processing0.217188.819220.1086
Template load and register function0.00010.039710.0001
states
state_id_array0.00070.266410.0007
state_identifier_array0.00100.389120.0005
Override
Cache load0.00170.71421140.0000
Sytem overhead
Fetch class attribute name0.00230.941730.0008
Fetch class attribute can translate value0.00070.281010.0007
class_abstraction
Instantiating content class attribute0.00000.003430.0000
XML
Image XML parsing0.00030.118210.0003
General
dbfile0.00271.0920220.0001
String conversion0.00000.002330.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.tplblog_entry/full.tplextension/community_design/design/suncana/override/templates/blog_entry/full.tplEdit templateOverride template
2content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
23content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
8content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
5content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
5content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
13content/datatype/view/ezxmltags/strong.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/strong.tplEdit templateOverride template
7content/datatype/view/ezxmltags/header.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/header.tplEdit templateOverride template
1content/datatype/view/ezkeyword.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezkeyword.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 73
 Number of unique templates used: 11

Time used to render debug report: 0.0002 secs