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...

  • My blog about 'Time is NOT money'... and value http://t.co/g2C6pZy0 12 years 10 weeks ago
  • I've found an excellent query logging and filtering module for Drupal. Not available via http://t.co/U1Xe92Th: http://t.co/2qvg1DgE 12 years 14 weeks ago
  • I've just spotted my first © 2011 at the bottom of a website. 12 years 14 weeks ago
  • @da_lune That's the spirit, oh, too late @gavinbrook, Wordpress is fantastic & now more than a blogging tool but Drupal = more functionality 12 years 18 weeks ago
  • @oliverpolden is having an amazing day for many reasons. I feel like giving back: http://t.co/JvKVVMBF Have a request? use the contact form. 12 years 18 weeks ago
  • The world's population is 7 billion. If a few 'competing' companies mutually helped each other get more customers business would be easy. 12 years 18 weeks ago
  • @Casablanca Amazing photos! Thank you for sharing. 12 years 19 weeks ago
  • Ahh, the Christmas Snow module for Drupal: http://t.co/QzvkQiT2 12 years 19 weeks ago
Oliver Polden