Use apache mod_deflate to compress your files

Posted by 6bytes at 29 October 2008

Category: Apache

Compressing CSS and JavaScript files will put a bit more load on the server but its worth doing as it will save you some bandwidth and your site will be delivered faster to your users/visitors.

Load mod_deflate

First you need to make sure you have mod_deflate module loaded.  Check you have this line in your httpd.conf file and if so, that it’s uncommented.  The line should look like this:

LoadModule deflate_module modules/mod_deflate.so

All following options can be put in httpd.conf file but just for keeping things organized I recommend creating a new file in the same folder called deflate.conf

Enable compression

To enable compression for everything type in the following:

SetOutputFilter DEFLATE

To enable compression only for certain types of files type in the following:

AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css
AddOutputFilterByType DEFLATE application/xml application/xhtml+xml application/rss+xml application/javascript application/x-javascript

Compression level

Available levels are 1 – 9 meaning 1 – weakest compression using least resources and 9 – strongest compression using the most resources of the server.   All modern servers have no problem with handling level 9.

DeflateCompressionLevel 9

Old browsers

To exclude browsers not fully supporting compression type in the following:

BrowserMatch ^Mozilla/4 gzip-only-text/html
BrowserMatch ^Mozilla/4\.0[678] no-gzip
BrowserMatch \bMSIE !no-gzip !gzip-only-text/html

Logs

Setting up a log file lets you know when and who requested your files as well as gives you information about how well your files were compressed.

DeflateFilterNote Input instream
DeflateFilterNote Output outstream
DeflateFilterNote Ratio ratio
LogFormat '"%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate
CustomLog logs/deflate_log deflate

Result

If you’ve created deflate.conf file it should look something like that:


SetOutputFilter DEFLATE
AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css
AddOutputFilterByType DEFLATE application/xml application/xhtml+xml application/rss+xml application/javascript application/x-javascript

DeflateCompressionLevel 9

BrowserMatch ^Mozilla/4 gzip-only-text/html
BrowserMatch ^Mozilla/4\.0[678] no-gzip
BrowserMatch \bMSIE !no-gzip !gzip-only-text/html

DeflateFilterNote Input instream
DeflateFilterNote Output outstream
DeflateFilterNote Ratio ratio

LogFormat '"%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate
CustomLog /var/log/deflate_log deflate

In your httpd.conf file add one line to include deflate.conf

Include /path/to/file/deflate.conf

Restart apache:

service httpd restart

If Apache starts without any problems your content should be compressed.

More detailed info can be found on Apache documentation here.

2 Comments

  1. Mikhailov Anatoly says
  2. Wojtek Kosinski says

    True, there is quite a few articles like that on the web. I had to read a few articles to achieve desired results which I’m sharing with everyone now.

    Reply

Leave a Reply

Leave a Reply
  • (required)
  • (required) (will not be published)