Making Drupal fly with Pressflow, varnish and more for performance

This article is currently a work in progress.

Drupal I believe is one of the best Open Source content management systems available and it's constantly improving. One of the reasons for its appeal is the amount of modules available that give it a vast array of functionality. This is however a drawback as well. All of this functionality comes at the cost of performance. Even a modest amount of modules left without any performance enhancements turned on will make the most basic of sites very slow. Turning on Drupal's Normal caching offers a significant boost because it caches pages to the database so they don't need to be built again but there's a hell of a lot more you can do. In a nutshell, imagine serving a cached version your website completely from memory without even touching the web server or file system. Of course, at some point requests do need to go through to Drupal and when that happens we can make Drupal perform close to the speed of compiled code.

The technologies that make this possible are reverse proxy caches such as Varnish, and OpCode caching such as APC and database caching with Memcache.

Notes:
Don't check cache for "SESS" (User is logged in - only Pressflow), "NO_CACHE" (User has recently posted), cron.php
Varnish module

Amazon instances

http://thecloudmarket.com/image/ami-9f9f70f6--pantheon-mercury-32-bit-1-0

Innodb

There are various advantages to using Innodb vs Myisam for some database tables. One big issue with Innodb can be the fact that the filesize cannot shrink when rows are deleted and of course the larger a file is, the longer it takes to process. However there is a setting, 'Using Per-Table Tablespaces', that offers several advantages, especially if you are dealing with large tables.
http://dev.mysql.com/doc/refman/5.5/en/innodb-multiple-tablespaces.html
The advantages are things like being able to store tables on separate physical disks.

Other stuff

Post new comment

By submitting this form, you accept the Mollom privacy policy.

User login

Author of...

  • @casablanca @philhawksworth ohhhh, ahhhh, argh! 14 years 3 weeks ago
  • What the? Updating two packages on Kubuntu... 4 minutes remaining... oh, one of them is #Skype. 14 years 3 weeks ago
  • Thanks @gavinbrook Seems #woopra is the only one that does more than monitoring. The tagging users feature looks very useful. 14 years 3 weeks ago
  • Any votes for: #woopra #chartbeat #mixpanel or #clicky or any other #realtimeanalytics suggestions? 14 years 3 weeks ago
  • Ohh, just having a look at the git instructions for my own Drupal project. Learning a lot about git in the process : -) goo.gl/ZKBo7 14 years 3 weeks ago
  • @philhawksworth @philpeace I'm slowly moving all my sites off Godaddy too but they don't have a proper way of transferring .co.uk sites!!! 14 years 3 weeks ago
  • enjoying a bit of javascript but what am I doing at late so work? 14 years 4 weeks ago
  • [GitHub] theteam added you to a team, lol 14 years 4 weeks ago
Oliver Polden