SlideShare a Scribd company logo
Drupal Performance Optimization
Best Practices
July 4, 2014
Ratnesh Kumar
2
Overview
• Drupal Performance
• Know the tools for performance Analysis
• Best Practices for Performance Optimization
– Application Level
– Server Configuration
– Database Configuration
• Common mistakes which causes Performance
bottlenecks
Drupal Performance
• Performance bottlenecks is a major issue with Drupal based
application
• Common understanding among people, product stakeholders
and web developers is:
 Drupal is not a right choice for large application with lot
of users and content.
 It consumes lot of memory and resources.
3
4
Drupal Performance
Why Drupal is Slow?
• Because it’s not configured/deployed correctly…
• Contents are dynamic not static.
• Bootstrap process is complex where series of events occurs
behind the scene:
 Establishing a database connection
 Loading all settings and modules
 Initializing a user session
 Mapping the URL to page callback
 Render the Page (theme initialization)
On every single page request all the above events occurs in backend.

Recommended for you

23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress

Some practical ways to speed up your WordPress website. Looking at plugins, configurations, do's & don'ts, server software and hardware changes.

wordpressspeed up wordpresswebsite speed
Understanding Web Cache
Understanding Web CacheUnderstanding Web Cache
Understanding Web Cache

Overview of using cache on websites and some of the implementations of improving your sites performance through cache.

prodigyviewcachephp
wordpress-performance-presentation
wordpress-performance-presentationwordpress-performance-presentation
wordpress-performance-presentation

PHP comes pre-installed with all modules by default, which can lead to heavy processing. It is better to compile PHP from source and only install required modules. Lightweight web servers like Nginx with PHP-FPM are faster than Apache for static and dynamic content since PHP execution is native rather than module-based. Caching, a CDN, Memcache, and optimizing WordPress, MySQL, and plugins can improve performance. Security measures include restricting access, removing default accounts and files, strong file permissions, and installing security modules.

5
Drupal Performance
When do you think about performance?
(Before/After Development)
 Discuss and freeze the performance related NFRs carefully
under requirement document, before starting the development.
 Set a goal for performance which needs to be achieved.
 Finalize Caching strategies.
Tools for performance Analysis
6
Tools for performance Analysis
 www.webpagetest.org
Google pageSpeed (Chrome add ons)
 Yslow (Firefox add ons)
 Apache Benchmarking
 www.whichloadfaster.com (compare with other sites)
 Drupal module – Devel
 top/htop ……. and lots more
Best Practices - Application Level

Recommended for you

World Wide Web Caching
World Wide Web CachingWorld Wide Web Caching
World Wide Web Caching

Web caching provides several benefits including bandwidth savings, reducing server load, and decreasing network latency. It works by intercepting HTTP requests and checking a local cache for the requested object before going to the origin server. Different caching approaches include proxy caching, reverse proxy caching, transparent proxy caching, and hierarchical caching. New techniques like adaptive caching and push caching aim to dynamically optimize cache placement near popular content or users.

Skalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.comSkalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.com

This document discusses scalable web application architecture. It describes using load balancing and database replication across multiple servers to handle high traffic volumes. It emphasizes using caching at various levels (PHP, databases, CDNs) and preprocessing data to improve performance. A CDN is recommended for distributing static resources globally to reduce latency and failure risk.

phpmysqlbarcamp
Client-side Website Optimization
Client-side Website OptimizationClient-side Website Optimization
Client-side Website Optimization

Did you know that 80% to 90% of the user's page-load time comes from components outside the firewall? Optimizing performance on the front end (e.g. from the client side) can enhance the user experience by reducing the response times of your web pages and making them load and render much faster.

assignmentwadeinfoiasi
7
Best Practices - Application Level
 Disable and Delete unused and non-essential modules
 Disable the Update Manager module on Production.
 Database logging (dblog) is enabled by default in Drupal 7, and errors can
fill up your database quickly.
 A better solution is to fix all PHP notices and warnings to reduce logging
overhead.
8
Best Practices - Application Level
 Put JS at the bottom of the page.
 Custom JS/CSS should be added in the application only using
drupal_add_js() and drupal_add_css() function respectively.
 Aggregate and minify JS/CSS file through Drupal Admin.
 Use the Fast 404 module to serve static 404s for image, icon,
CSS, or other static files, rather than bootstrapping Drupal.
Best Practices – Server Configuration
9
Best Practices – Server Configuration
 Cache PHP with APC(Alternative PHP cache)
 Cache everything to reduce the page load time for
anonymous user (Boost, Memcache/Varnish).

Recommended for you

Web performance Talk
Web performance TalkWeb performance Talk
Web performance Talk

This slide is about the basics of web performance gives the insite of all the things we can do to achieve high performing web apps

front end engineeringweb speedperformance engineering
Website performance optimization QA
Website performance optimization QAWebsite performance optimization QA
Website performance optimization QA

This document discusses web performance optimization and provides guidance on ensuring high performance web applications. It covers why performance is important, key performance metrics to measure, common areas to profile like client and server-side processing, requirements for performance testing like goals and load thresholds, and tools for performance testing and profiling like JMeter, dotTrace and SQL Server Profiler. The document also outlines best practices for integrating performance testing into the development workflow when issues are found or time allows before a release.

Caching
CachingCaching
Caching

A brief overview of caching mechanisms in a web application. Taking a look at the different layers of caching and how to utilize them in a PHP code base. We also compare Redis and MemCached discussing their advantages and disadvantages.

memcachedrediscaching
10
Best Practices – Server Configuration
 Configure CRON to be executed at a certain timestamp in a day, instead of
executing this on every request. Drupal executes cron hook on every page request.
 CDN Integration – to store all static files e.g. css, js and images.
 Leverage browser caching
 Optimize images to reduce the total page size.
11
Best Practices – Server Configuration
 Boost + Memcache – Works best in most of the case as it
solves performance issue for anonymous and authenticated user
both
Boost provides static page caching for Drupal enabling a very significant performance and
scalability boost for sites that receive mostly anonymous traffic
 Precache everything through warmup script
 Use cache-expire module to update cache on node insert/update/detele.
12
Best Practices – Server Configuration
13
Best Practices – Server Configuration
• Memcache
You can use the Memcache module to move some common cache queries out of the database
and into memory. Information held in memory will always be retrieved more quickly than
information retrieved from a database query.
• APC (Alternative PHP Cache)
 PHP is an interpreted language, which means the files have to be reduced down into
opcodes in order to actually be executed by the server.
 Once APC is installed on the server and configured, it will store the intermediate code of
PHP files in memory so that every request does not result in fetching all those PHP files off disk
and interpreting the files every time.

Recommended for you

WordCamp RVA
WordCamp RVAWordCamp RVA
WordCamp RVA

The document discusses optimizing WordPress performance. It recommends minimizing frontend assets like images, implementing caching for assets and application chunks, optimizing themes and plugins, and choosing efficient server setups. Specific plugins like W3 Total Cache and a CDN can improve performance by up to 10 times by caching static content. Nginx is presented as a faster alternative to Apache. Overall, the key takeaways are to simplify code, minimize requests, optimize caching, and reduce payload sizes to improve perceived and actual performance.

Web Optimization Level: Paranoid
Web Optimization Level: ParanoidWeb Optimization Level: Paranoid
Web Optimization Level: Paranoid

The document discusses various techniques for optimizing web performance, ranging from beginner to advanced levels. At the beginner level, it recommends avoiding redirects, enabling client-side caching, and reducing DOM elements. At the medium level, it suggests minifying JavaScript and CSS. More advanced techniques include image compression, combining files, and server-side gzip compression. The document also provides optimization tips for databases like MongoDB and recommends using asynchronous and non-blocking I/O for costly operations. It advocates for client-side templating to reduce bandwidth usage and improve cacheability.

optimizationwebsiteparanoid
Building low latency java applications with ehcache
Building low latency java applications with ehcacheBuilding low latency java applications with ehcache
Building low latency java applications with ehcache

Dhruv Kumar's talk from http://www.meetup.com/SF-Bay-Area-Large-Scale-Production-Engineering/events/124095182/

ehcache#lspe
14
Best Practices – Server Configuration
• Integrate CDN to store all static files(JS/Images/CSS)
A content delivery network (CDN) is a collection of web servers distributed across multiple
locations to deliver content more efficiently to users. The server selected for delivering content to
a specific user is typically based on a measure of network proximity.
15
Best Practices – Server Configuration
• Leverage Brower Caching
 What browser caching does:
 “Remember" the resources that the browser has already loaded. When a visitor goes to
another page on your website your logo or CSS file does not need to be loaded again,
because the browser has them "remembered". The end result is that your pages load
much faster.
 Browser caching can be enabled with few configuration added in the .htaccess file on the
server.
• Set expiry time of static contents
<IfModule mod_expires.c>
# Enable expirations.
ExpiresActive On
ExpiresByType image/jpg "access 1 month"
16
Best Practices – Server Configuration
• Leverage Brower Caching
• Set max-age header
<FilesMatch "(.js.gz|.css.gz)$">
Header set Cache-Control "max-age=2678400, public"
ExpiresActive On
ExpiresDefault "access plus 1 month“
 Requirements:
• mod_expire and mod_header modules needs to be installed and enabled on the
server(Apache).
17
Best Practices – Server Configuration
• CRON Configuration
Misconfiguration of CRON settings results into major performance issue as Drupal executes all
the cron hooks on every single page request by default.
 Configure CRON to be executed at a certain timestamp in a day
 Elysia cron module works perfectly for configuring cron.
 It extends Drupal standard cron, allowing a fine grain control over each task and several
ways to add custom cron jobs to your site.

Recommended for you

Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites

Rami Jarvinen discusses optimizing performance on Drupal sites. He outlines several caching layers that can be implemented including PHP opcode caching, Drupal internal caching, page caching, and reverse proxy caching using Boost or Varnish. He also discusses scaling Drupal through techniques such as MySQL master-slave configuration, serving static files from Nginx/lighttpd, and adding frontend servers. Profiling with tools like Xdebug can help identify SQL bottlenecks to optimize. The optimal caching and performance strategy depends on each site's specific usage and hosting environment.

drupaldrupalcampdrupalcamp estonia
Fluent 2012 v2
Fluent 2012   v2Fluent 2012   v2
Fluent 2012 v2

This document discusses how bookmarklets can function as applications by interacting with web pages in a secure manner. It describes how the bookmarklet uses elementFromPoint for fast hit detection, resets CSS to robustly render its UI, and transmits data to a server through signed cross-domain POST messages for security. Examples of embedding the bookmarklet code on a page and customizing its appearance are also provided.

Make Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speedMake Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speed

What does it mean when someone says “My Site is slow now”? What is page speed? How do you measure it? How can you make it faster? We’ll try to answer these questions, provide you with a set of tools to use and explain how this relates to your server load. We will cover: - What is page load speed? – Tools used to measure performance of your pages and site – Six Key Improvements to make Drupal “run fast” ++ Performance Module settings and how they work ++ Caching – biggest gainer and how to implement Boost ++ Other quick hits: off loading search, tweaking settings & why running crons is important ++ Ask your host about APC and how to make sure its set up correctly ++ Dare we look at the database? Easy changes that will help a lot! - Monitoring Best practices – what to set up to make sure you know what is going on with your server – What if you get slashdoted? Recommendation on how to quickly take cover from a rhino.

performance drupal cms lamp page speed linux sys a
18
Best Practices – Server Configuration
• CRON Configuration
 Configuration on Server side:
Connect to server through ssh
Login as root user (sudo su)
Command to view/edit crontab file
 crontab –l (to view the list of cron script configured on the server)
 crontab –e (opens the crontab configuration)
Add the below line to excute the cron at 2:10 AM daily
10 2 * * * /usr/bin/wget -O - -q -t 1
http://www.createdbespoke.com/sites/all/modules/community/elysia_cron/cron.php?cr
on_key=sfaslsfklsfjlksfjlfsaf
Save the file and quit – wq
Best Practices – Database
19
Best Practices – Database
 Do not use InnoDB for the semaphore table, use Memory
ALTER TABLE semaphore ENGINE=MEMORY;
 innodb_buffer_pool_size 70-80% of memory is a safe bet. I set it to 12G on 16GB box.
 innodb_log_file_size – This depends on your recovery speed needs but 256M seems to be a
good balance between reasonable recovery time and good performance
 innodb_log_buffer_size=4M is good for most cases unless you’re piping large blobs to Innodb
in this case increase it a bit.
20
Best Practices – Database
 Enable MySQL query cache (i.e. query_cache_size)
 Find Slow query through slow query log file.
 Create indexes to optimize the query

Recommended for you

Cloud computing 3702
Cloud computing 3702Cloud computing 3702
Cloud computing 3702

This document provides an overview of scaling DotNetNuke in the cloud. It discusses infrastructure as a service models and configuring DotNetNuke for highly available, load balanced environments. Specific topics covered include setting up availability zones, load balancers, configuring web servers uniformly, replicating files, database mirroring, caching, and scheduling tasks. References are provided for additional resources on topics like shared configuration, distributed file system replication, and setting up application request routing.

Scaling PHP apps
Scaling PHP appsScaling PHP apps
Scaling PHP apps

Matteo Moretti discusses scaling PHP applications. He covers scaling the web server, sessions, database, filesystem, asynchronous tasks, and logging. The key aspects are decoupling services, using caching, moving to external services like Redis, S3, and RabbitMQ, and allowing those services to scale automatically using techniques like auto-scaling. Sharding the database is difficult to implement and should only be done if really needed.

DrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizingDrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizing

This document discusses various techniques for improving the frontend performance of Drupal websites. It begins by introducing the speaker and describing the goals of the presentation. The bulk of the document then provides recommendations in three areas: backend server optimizations like caching, parallel downloads and gzip compression; tools for measuring performance; and frontend optimizations like minimizing requests, lazy loading images, and improving CSS and JavaScript. The document encourages proper performance diagnosis and defines goals before implementing solutions.

drupalapachefrontend
20
Questions?
Questions?
20
Thanks… 

More Related Content

What's hot

Caching Strategies
Caching StrategiesCaching Strategies
Caching Strategies
Michal Špaček
 
Wordpress optimization
Wordpress optimizationWordpress optimization
Wordpress optimization
Almog Baku
 
WordPress Hosting Best Practices - Do's and Don't s | WordPress Trivandrum
WordPress Hosting Best Practices - Do's and Don't s  | WordPress TrivandrumWordPress Hosting Best Practices - Do's and Don't s  | WordPress Trivandrum
WordPress Hosting Best Practices - Do's and Don't s | WordPress Trivandrum
WordPress Trivandrum
 
23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress
Zero Point Development
 
Understanding Web Cache
Understanding Web CacheUnderstanding Web Cache
Understanding Web Cache
ProdigyView
 
wordpress-performance-presentation
wordpress-performance-presentationwordpress-performance-presentation
wordpress-performance-presentation
Arun Janarthanan
 
World Wide Web Caching
World Wide Web CachingWorld Wide Web Caching
World Wide Web Caching
ersanbilik
 
Skalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.comSkalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.com
Spodek 2.0
 
Client-side Website Optimization
Client-side Website OptimizationClient-side Website Optimization
Client-side Website Optimization
Radu Pintilie
 
Web performance Talk
Web performance TalkWeb performance Talk
Web performance Talk
Prasoon Agrawal
 
Website performance optimization QA
Website performance optimization QAWebsite performance optimization QA
Website performance optimization QA
Denis Dudaev
 
Caching
CachingCaching
Caching
Nascenia IT
 
WordCamp RVA
WordCamp RVAWordCamp RVA
WordCamp RVA
codearachnid_test
 
Web Optimization Level: Paranoid
Web Optimization Level: ParanoidWeb Optimization Level: Paranoid
Web Optimization Level: Paranoid
robin_sy
 
Building low latency java applications with ehcache
Building low latency java applications with ehcacheBuilding low latency java applications with ehcache
Building low latency java applications with ehcache
Chris Westin
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
drupalcampest
 
Fluent 2012 v2
Fluent 2012   v2Fluent 2012   v2
Fluent 2012 v2
Shalendra Chhabra
 

What's hot (17)

Caching Strategies
Caching StrategiesCaching Strategies
Caching Strategies
 
Wordpress optimization
Wordpress optimizationWordpress optimization
Wordpress optimization
 
WordPress Hosting Best Practices - Do's and Don't s | WordPress Trivandrum
WordPress Hosting Best Practices - Do's and Don't s  | WordPress TrivandrumWordPress Hosting Best Practices - Do's and Don't s  | WordPress Trivandrum
WordPress Hosting Best Practices - Do's and Don't s | WordPress Trivandrum
 
23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress23 Ways To Speed Up WordPress
23 Ways To Speed Up WordPress
 
Understanding Web Cache
Understanding Web CacheUnderstanding Web Cache
Understanding Web Cache
 
wordpress-performance-presentation
wordpress-performance-presentationwordpress-performance-presentation
wordpress-performance-presentation
 
World Wide Web Caching
World Wide Web CachingWorld Wide Web Caching
World Wide Web Caching
 
Skalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.comSkalowalna architektura na przykładzie soccerway.com
Skalowalna architektura na przykładzie soccerway.com
 
Client-side Website Optimization
Client-side Website OptimizationClient-side Website Optimization
Client-side Website Optimization
 
Web performance Talk
Web performance TalkWeb performance Talk
Web performance Talk
 
Website performance optimization QA
Website performance optimization QAWebsite performance optimization QA
Website performance optimization QA
 
Caching
CachingCaching
Caching
 
WordCamp RVA
WordCamp RVAWordCamp RVA
WordCamp RVA
 
Web Optimization Level: Paranoid
Web Optimization Level: ParanoidWeb Optimization Level: Paranoid
Web Optimization Level: Paranoid
 
Building low latency java applications with ehcache
Building low latency java applications with ehcacheBuilding low latency java applications with ehcache
Building low latency java applications with ehcache
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
 
Fluent 2012 v2
Fluent 2012   v2Fluent 2012   v2
Fluent 2012 v2
 

Similar to Drupal performance optimization Best Practices

Make Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speedMake Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speed
Andy Kucharski
 
Cloud computing 3702
Cloud computing 3702Cloud computing 3702
Cloud computing 3702
Jess Coburn
 
Scaling PHP apps
Scaling PHP appsScaling PHP apps
Scaling PHP apps
Matteo Moretti
 
DrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizingDrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizing
Ashok Modi
 
WordPress At Scale. WordCamp Dhaka 2019
WordPress At Scale. WordCamp Dhaka 2019WordPress At Scale. WordCamp Dhaka 2019
WordPress At Scale. WordCamp Dhaka 2019
Anam Ahmed
 
Caching 101
Caching 101Caching 101
Caching 101
Andy Melichar
 
Improving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve InternetImproving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve Internet
Achieve Internet
 
Improving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve InternetImproving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve Internet
Achieve Internet
 
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
WordCamp Harare
 
WordCamp Harare 2016 - Site Speed = Success
WordCamp Harare 2016 - Site Speed = SuccessWordCamp Harare 2016 - Site Speed = Success
WordCamp Harare 2016 - Site Speed = Success
Anthony Somerset
 
Introduction to Drupal - Installation, Anatomy, Terminologies
Introduction to Drupal - Installation, Anatomy, TerminologiesIntroduction to Drupal - Installation, Anatomy, Terminologies
Introduction to Drupal - Installation, Anatomy, Terminologies
Gerald Villorente
 
PAC 2019 virtual Mark Tomlinson
PAC 2019 virtual Mark TomlinsonPAC 2019 virtual Mark Tomlinson
PAC 2019 virtual Mark Tomlinson
Neotys
 
Orlando DNN Usergroup Pres 12/06/11
Orlando DNN Usergroup Pres 12/06/11Orlando DNN Usergroup Pres 12/06/11
Orlando DNN Usergroup Pres 12/06/11
Jess Coburn
 
Make Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speedMake Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speed
Promet Source
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
Exove
 
Speeding Up The Snail
Speeding Up The SnailSpeeding Up The Snail
Speeding Up The Snail
Marcus Deglos
 
Optimizing Drupal Performance. Tips and Tricks
Optimizing Drupal Performance. Tips and TricksOptimizing Drupal Performance. Tips and Tricks
Optimizing Drupal Performance. Tips and Tricks
Timur Kamanin
 
Drupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp NorthDrupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp North
Philip Norton
 
Performance engineering
Performance engineeringPerformance engineering
Performance engineering
Franz Allan See
 
Drupal caching
Drupal cachingDrupal caching
Drupal caching
Exove
 

Similar to Drupal performance optimization Best Practices (20)

Make Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speedMake Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speed
 
Cloud computing 3702
Cloud computing 3702Cloud computing 3702
Cloud computing 3702
 
Scaling PHP apps
Scaling PHP appsScaling PHP apps
Scaling PHP apps
 
DrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizingDrupalCampLA 2011 - Drupal frontend-optimizing
DrupalCampLA 2011 - Drupal frontend-optimizing
 
WordPress At Scale. WordCamp Dhaka 2019
WordPress At Scale. WordCamp Dhaka 2019WordPress At Scale. WordCamp Dhaka 2019
WordPress At Scale. WordCamp Dhaka 2019
 
Caching 101
Caching 101Caching 101
Caching 101
 
Improving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve InternetImproving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve Internet
 
Improving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve InternetImproving Website Performance with Memecached Webinar | Achieve Internet
Improving Website Performance with Memecached Webinar | Achieve Internet
 
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
Site Speed = Success – Optimising WordPress from the Server Up - Presented by...
 
WordCamp Harare 2016 - Site Speed = Success
WordCamp Harare 2016 - Site Speed = SuccessWordCamp Harare 2016 - Site Speed = Success
WordCamp Harare 2016 - Site Speed = Success
 
Introduction to Drupal - Installation, Anatomy, Terminologies
Introduction to Drupal - Installation, Anatomy, TerminologiesIntroduction to Drupal - Installation, Anatomy, Terminologies
Introduction to Drupal - Installation, Anatomy, Terminologies
 
PAC 2019 virtual Mark Tomlinson
PAC 2019 virtual Mark TomlinsonPAC 2019 virtual Mark Tomlinson
PAC 2019 virtual Mark Tomlinson
 
Orlando DNN Usergroup Pres 12/06/11
Orlando DNN Usergroup Pres 12/06/11Orlando DNN Usergroup Pres 12/06/11
Orlando DNN Usergroup Pres 12/06/11
 
Make Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speedMake Drupal Run Fast - increase page load speed
Make Drupal Run Fast - increase page load speed
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
 
Speeding Up The Snail
Speeding Up The SnailSpeeding Up The Snail
Speeding Up The Snail
 
Optimizing Drupal Performance. Tips and Tricks
Optimizing Drupal Performance. Tips and TricksOptimizing Drupal Performance. Tips and Tricks
Optimizing Drupal Performance. Tips and Tricks
 
Drupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp NorthDrupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp North
 
Performance engineering
Performance engineeringPerformance engineering
Performance engineering
 
Drupal caching
Drupal cachingDrupal caching
Drupal caching
 

Recently uploaded

20240702 QFM021 Machine Intelligence Reading List June 2024
20240702 QFM021 Machine Intelligence Reading List June 202420240702 QFM021 Machine Intelligence Reading List June 2024
20240702 QFM021 Machine Intelligence Reading List June 2024
Matthew Sinclair
 
Cookies program to display the information though cookie creation
Cookies program to display the information though cookie creationCookies program to display the information though cookie creation
Cookies program to display the information though cookie creation
shanthidl1
 
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptxRPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
SynapseIndia
 
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyyActive Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
RaminGhanbari2
 
What's New in Copilot for Microsoft365 May 2024.pptx
What's New in Copilot for Microsoft365 May 2024.pptxWhat's New in Copilot for Microsoft365 May 2024.pptx
What's New in Copilot for Microsoft365 May 2024.pptx
Stephanie Beckett
 
Password Rotation in 2024 is still Relevant
Password Rotation in 2024 is still RelevantPassword Rotation in 2024 is still Relevant
Password Rotation in 2024 is still Relevant
Bert Blevins
 
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALLBLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
Liveplex
 
What’s New in Teams Calling, Meetings and Devices May 2024
What’s New in Teams Calling, Meetings and Devices May 2024What’s New in Teams Calling, Meetings and Devices May 2024
What’s New in Teams Calling, Meetings and Devices May 2024
Stephanie Beckett
 
Transcript: Details of description part II: Describing images in practice - T...
Transcript: Details of description part II: Describing images in practice - T...Transcript: Details of description part II: Describing images in practice - T...
Transcript: Details of description part II: Describing images in practice - T...
BookNet Canada
 
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdfWhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
ArgaBisma
 
20240705 QFM024 Irresponsible AI Reading List June 2024
20240705 QFM024 Irresponsible AI Reading List June 202420240705 QFM024 Irresponsible AI Reading List June 2024
20240705 QFM024 Irresponsible AI Reading List June 2024
Matthew Sinclair
 
WPRiders Company Presentation Slide Deck
WPRiders Company Presentation Slide DeckWPRiders Company Presentation Slide Deck
WPRiders Company Presentation Slide Deck
Lidia A.
 
How to Build a Profitable IoT Product.pptx
How to Build a Profitable IoT Product.pptxHow to Build a Profitable IoT Product.pptx
How to Build a Profitable IoT Product.pptx
Adam Dunkels
 
Best Practices for Effectively Running dbt in Airflow.pdf
Best Practices for Effectively Running dbt in Airflow.pdfBest Practices for Effectively Running dbt in Airflow.pdf
Best Practices for Effectively Running dbt in Airflow.pdf
Tatiana Al-Chueyr
 
Manual | Product | Research Presentation
Manual | Product | Research PresentationManual | Product | Research Presentation
Manual | Product | Research Presentation
welrejdoall
 
Comparison Table of DiskWarrior Alternatives.pdf
Comparison Table of DiskWarrior Alternatives.pdfComparison Table of DiskWarrior Alternatives.pdf
Comparison Table of DiskWarrior Alternatives.pdf
Andrey Yasko
 
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-InTrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
TrustArc
 
Calgary MuleSoft Meetup APM and IDP .pptx
Calgary MuleSoft Meetup APM and IDP .pptxCalgary MuleSoft Meetup APM and IDP .pptx
Calgary MuleSoft Meetup APM and IDP .pptx
ishalveerrandhawa1
 
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdfBT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
Neo4j
 
Pigging Solutions Sustainability brochure.pdf
Pigging Solutions Sustainability brochure.pdfPigging Solutions Sustainability brochure.pdf
Pigging Solutions Sustainability brochure.pdf
Pigging Solutions
 

Recently uploaded (20)

20240702 QFM021 Machine Intelligence Reading List June 2024
20240702 QFM021 Machine Intelligence Reading List June 202420240702 QFM021 Machine Intelligence Reading List June 2024
20240702 QFM021 Machine Intelligence Reading List June 2024
 
Cookies program to display the information though cookie creation
Cookies program to display the information though cookie creationCookies program to display the information though cookie creation
Cookies program to display the information though cookie creation
 
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptxRPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
RPA In Healthcare Benefits, Use Case, Trend And Challenges 2024.pptx
 
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyyActive Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
Active Inference is a veryyyyyyyyyyyyyyyyyyyyyyyy
 
What's New in Copilot for Microsoft365 May 2024.pptx
What's New in Copilot for Microsoft365 May 2024.pptxWhat's New in Copilot for Microsoft365 May 2024.pptx
What's New in Copilot for Microsoft365 May 2024.pptx
 
Password Rotation in 2024 is still Relevant
Password Rotation in 2024 is still RelevantPassword Rotation in 2024 is still Relevant
Password Rotation in 2024 is still Relevant
 
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALLBLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
BLOCKCHAIN FOR DUMMIES: GUIDEBOOK FOR ALL
 
What’s New in Teams Calling, Meetings and Devices May 2024
What’s New in Teams Calling, Meetings and Devices May 2024What’s New in Teams Calling, Meetings and Devices May 2024
What’s New in Teams Calling, Meetings and Devices May 2024
 
Transcript: Details of description part II: Describing images in practice - T...
Transcript: Details of description part II: Describing images in practice - T...Transcript: Details of description part II: Describing images in practice - T...
Transcript: Details of description part II: Describing images in practice - T...
 
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdfWhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
WhatsApp Image 2024-03-27 at 08.19.52_bfd93109.pdf
 
20240705 QFM024 Irresponsible AI Reading List June 2024
20240705 QFM024 Irresponsible AI Reading List June 202420240705 QFM024 Irresponsible AI Reading List June 2024
20240705 QFM024 Irresponsible AI Reading List June 2024
 
WPRiders Company Presentation Slide Deck
WPRiders Company Presentation Slide DeckWPRiders Company Presentation Slide Deck
WPRiders Company Presentation Slide Deck
 
How to Build a Profitable IoT Product.pptx
How to Build a Profitable IoT Product.pptxHow to Build a Profitable IoT Product.pptx
How to Build a Profitable IoT Product.pptx
 
Best Practices for Effectively Running dbt in Airflow.pdf
Best Practices for Effectively Running dbt in Airflow.pdfBest Practices for Effectively Running dbt in Airflow.pdf
Best Practices for Effectively Running dbt in Airflow.pdf
 
Manual | Product | Research Presentation
Manual | Product | Research PresentationManual | Product | Research Presentation
Manual | Product | Research Presentation
 
Comparison Table of DiskWarrior Alternatives.pdf
Comparison Table of DiskWarrior Alternatives.pdfComparison Table of DiskWarrior Alternatives.pdf
Comparison Table of DiskWarrior Alternatives.pdf
 
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-InTrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
TrustArc Webinar - 2024 Data Privacy Trends: A Mid-Year Check-In
 
Calgary MuleSoft Meetup APM and IDP .pptx
Calgary MuleSoft Meetup APM and IDP .pptxCalgary MuleSoft Meetup APM and IDP .pptx
Calgary MuleSoft Meetup APM and IDP .pptx
 
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdfBT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
BT & Neo4j: Knowledge Graphs for Critical Enterprise Systems.pptx.pdf
 
Pigging Solutions Sustainability brochure.pdf
Pigging Solutions Sustainability brochure.pdfPigging Solutions Sustainability brochure.pdf
Pigging Solutions Sustainability brochure.pdf
 

Drupal performance optimization Best Practices

  • 1. Drupal Performance Optimization Best Practices July 4, 2014 Ratnesh Kumar
  • 2. 2 Overview • Drupal Performance • Know the tools for performance Analysis • Best Practices for Performance Optimization – Application Level – Server Configuration – Database Configuration • Common mistakes which causes Performance bottlenecks
  • 3. Drupal Performance • Performance bottlenecks is a major issue with Drupal based application • Common understanding among people, product stakeholders and web developers is:  Drupal is not a right choice for large application with lot of users and content.  It consumes lot of memory and resources. 3
  • 4. 4 Drupal Performance Why Drupal is Slow? • Because it’s not configured/deployed correctly… • Contents are dynamic not static. • Bootstrap process is complex where series of events occurs behind the scene:  Establishing a database connection  Loading all settings and modules  Initializing a user session  Mapping the URL to page callback  Render the Page (theme initialization) On every single page request all the above events occurs in backend.
  • 5. 5 Drupal Performance When do you think about performance? (Before/After Development)  Discuss and freeze the performance related NFRs carefully under requirement document, before starting the development.  Set a goal for performance which needs to be achieved.  Finalize Caching strategies.
  • 7. 6 Tools for performance Analysis  www.webpagetest.org Google pageSpeed (Chrome add ons)  Yslow (Firefox add ons)  Apache Benchmarking  www.whichloadfaster.com (compare with other sites)  Drupal module – Devel  top/htop ……. and lots more
  • 8. Best Practices - Application Level
  • 9. 7 Best Practices - Application Level  Disable and Delete unused and non-essential modules  Disable the Update Manager module on Production.  Database logging (dblog) is enabled by default in Drupal 7, and errors can fill up your database quickly.  A better solution is to fix all PHP notices and warnings to reduce logging overhead.
  • 10. 8 Best Practices - Application Level  Put JS at the bottom of the page.  Custom JS/CSS should be added in the application only using drupal_add_js() and drupal_add_css() function respectively.  Aggregate and minify JS/CSS file through Drupal Admin.  Use the Fast 404 module to serve static 404s for image, icon, CSS, or other static files, rather than bootstrapping Drupal.
  • 11. Best Practices – Server Configuration
  • 12. 9 Best Practices – Server Configuration  Cache PHP with APC(Alternative PHP cache)  Cache everything to reduce the page load time for anonymous user (Boost, Memcache/Varnish).
  • 13. 10 Best Practices – Server Configuration  Configure CRON to be executed at a certain timestamp in a day, instead of executing this on every request. Drupal executes cron hook on every page request.  CDN Integration – to store all static files e.g. css, js and images.  Leverage browser caching  Optimize images to reduce the total page size.
  • 14. 11 Best Practices – Server Configuration  Boost + Memcache – Works best in most of the case as it solves performance issue for anonymous and authenticated user both Boost provides static page caching for Drupal enabling a very significant performance and scalability boost for sites that receive mostly anonymous traffic  Precache everything through warmup script  Use cache-expire module to update cache on node insert/update/detele.
  • 15. 12 Best Practices – Server Configuration
  • 16. 13 Best Practices – Server Configuration • Memcache You can use the Memcache module to move some common cache queries out of the database and into memory. Information held in memory will always be retrieved more quickly than information retrieved from a database query. • APC (Alternative PHP Cache)  PHP is an interpreted language, which means the files have to be reduced down into opcodes in order to actually be executed by the server.  Once APC is installed on the server and configured, it will store the intermediate code of PHP files in memory so that every request does not result in fetching all those PHP files off disk and interpreting the files every time.
  • 17. 14 Best Practices – Server Configuration • Integrate CDN to store all static files(JS/Images/CSS) A content delivery network (CDN) is a collection of web servers distributed across multiple locations to deliver content more efficiently to users. The server selected for delivering content to a specific user is typically based on a measure of network proximity.
  • 18. 15 Best Practices – Server Configuration • Leverage Brower Caching  What browser caching does:  “Remember" the resources that the browser has already loaded. When a visitor goes to another page on your website your logo or CSS file does not need to be loaded again, because the browser has them "remembered". The end result is that your pages load much faster.  Browser caching can be enabled with few configuration added in the .htaccess file on the server. • Set expiry time of static contents <IfModule mod_expires.c> # Enable expirations. ExpiresActive On ExpiresByType image/jpg "access 1 month"
  • 19. 16 Best Practices – Server Configuration • Leverage Brower Caching • Set max-age header <FilesMatch "(.js.gz|.css.gz)$"> Header set Cache-Control "max-age=2678400, public" ExpiresActive On ExpiresDefault "access plus 1 month“  Requirements: • mod_expire and mod_header modules needs to be installed and enabled on the server(Apache).
  • 20. 17 Best Practices – Server Configuration • CRON Configuration Misconfiguration of CRON settings results into major performance issue as Drupal executes all the cron hooks on every single page request by default.  Configure CRON to be executed at a certain timestamp in a day  Elysia cron module works perfectly for configuring cron.  It extends Drupal standard cron, allowing a fine grain control over each task and several ways to add custom cron jobs to your site.
  • 21. 18 Best Practices – Server Configuration • CRON Configuration  Configuration on Server side: Connect to server through ssh Login as root user (sudo su) Command to view/edit crontab file  crontab –l (to view the list of cron script configured on the server)  crontab –e (opens the crontab configuration) Add the below line to excute the cron at 2:10 AM daily 10 2 * * * /usr/bin/wget -O - -q -t 1 http://www.createdbespoke.com/sites/all/modules/community/elysia_cron/cron.php?cr on_key=sfaslsfklsfjlksfjlfsaf Save the file and quit – wq
  • 22. Best Practices – Database
  • 23. 19 Best Practices – Database  Do not use InnoDB for the semaphore table, use Memory ALTER TABLE semaphore ENGINE=MEMORY;  innodb_buffer_pool_size 70-80% of memory is a safe bet. I set it to 12G on 16GB box.  innodb_log_file_size – This depends on your recovery speed needs but 256M seems to be a good balance between reasonable recovery time and good performance  innodb_log_buffer_size=4M is good for most cases unless you’re piping large blobs to Innodb in this case increase it a bit.
  • 24. 20 Best Practices – Database  Enable MySQL query cache (i.e. query_cache_size)  Find Slow query through slow query log file.  Create indexes to optimize the query