Before I move into PHP Speedy, a small background won’t hurt much! Until a few days back, whenever I hear the word optimization, my brain quickly shows a few keywords in my mental screen: “query optimization, page caching, opcode, etc”. All these terms and the associated work relates to the optimization of a web application in the back-end. This has been serving my need pretty good, until I became aware about the excellent 13-point front-end optimization techniques from Yahoo (thanks Emran bhai).
At first I was a bit skeptical, but as soon as I started seeing the points – I knew its importance. Without much delay, I gave it a short in my latest project at work. And the tool that made it a less than 10 minute work is: PHP Speedy. I am literally speechless with it’s performance and way of working. Just in 10 minuets, It upgraded the Yslow grade of our project from 43 to 88. Just like a magic touch!
Now, let’s see what Yslow Grade is (for those who are not yet using it) and how php-speedy helps to upgrade it. Hope this enlightens someone like me
YSlow and Yslow Grade
This is yahoo’s plugin for firebug. It analyzes a page using 13 metrics (all with very details descriptions that are linked to), and gives a grade for each one, as well as an overall grade. This 13 metrics are some key points of optimization. They are listed below :
- Make fewer HTTP requests
- Use a CDN
- Add an Expires header
- Gzip components
- Put CSS at the top
- Put JS at the bottom
- Avoid CSS expressions
- Make JS and CSS external
- Reduce DNS lookups
- Minify JS
- Avoid redirects
- Remove duplicate scripts
- Configure ETags
So, a higher YSlow grade indicates a highly optimized web site. And using php-speedy, you can upgrade the grade of most of this metrics and get a higher Yslow grade in minutes.
To know more about Yslow, see http://developer.yahoo.com/yslow/.
PHP Speedy and it’s magic
PHP Speedy says about itself,
PHP Speedy is a script that you can install on your web server to automatically speed up the download time of your web pages.
PHP Speedy automatically joined together all the appropriate files (javascripts and css), remove duplications and compressed them. As a result, the size of the data and the number of http call, both are minimized. Again, it Gzip the total output while sending to browser. Moreover, all this options are configurable.
See the PHP Speedy site for downloading and installation instructions.
Hope you are already convinced to use great optimization tool. Before ending, I am listing some common problems of using PHP Speedy and their solutions. (This points was wrote by Charles in his comment).
- In-page javascript: If you have any in-page javascript in the section, all the javascript will break. Move it either into a separate js file loaded in the same spot or move it to after the beginning of the tag.
- Relative CSS URL links: If there are Relative CSS URL links (for background images, for example), they will become malformed. Change all URL relative links in CSS to absolute references. (if you turn on php speedy and your backgrounds disappear, this will fix it)
- No JavaScript from PHP: You can’t use javascripts generated by PHP. Find another way (one workaround – change it to inline javascript code after the tag).
- No JavaScript with arguments: If you have javascripts that you can call with arguments (like protosafe, for example), you can’t use them. Find another way.
Happy Optimizing!