Enable GZIP Compression on nginx Servers
Speed kills, and there's nothing like a speedy website. When you come to this blog, I want you to have a great experience, which is why I've worked tirelessly to compress every asset and avoid unnecessary synchronous interactions. In reviewing my site with Google Pagespeed Insights, I noticed that my virtual private server from Media Temple wasn't configured to serve assets gzip compressed. Oh no! Here's how I enabled gzip compression and made my site miles faster!
Create a file at /etc/nginx/conf.d/gzip.conf with the following content:
gzip on;
gzip_proxied any;
gzip_types text/plain text/xml text/css application/x-javascript;
gzip_vary on;
gzip_disable "MSIE [1-6]\.(?!.*SV1)";
With that file now in place, restart your server and you will now be serving site assets with gzip compression. Google takes site speed into account when ranking and placing your sites in their search engine so do your users a favor and strive for the fastest site possible -- especially for mobile users!
![CSS Filters]()
CSS filter support recently landed within WebKit nightlies. CSS filters provide a method for modifying the rendering of a basic DOM element, image, or video. CSS filters allow for blurring, warping, and modifying the color intensity of elements. Let's have...
![CSS Animations Between Media Queries]()
CSS animations are right up there with sliced bread. CSS animations are efficient because they can be hardware accelerated, they require no JavaScript overhead, and they are composed of very little CSS code. Quite often we add CSS transforms to elements via CSS during...
![CSS Background Animations]()
Background animations are an awesome touch when used correctly. In the past, I used MooTools to animate a background position. Luckily these days CSS animations are widely supported enough to rely on them to take over JavaScript-based animation tasks. The following simple CSS snippet animates...
![RealTime Stock Quotes with MooTools Request.Stocks and YQL]()
It goes without saying but MooTools' inheritance pattern allows for creation of small, simple classes that possess immense power. One example of that power is a class that inherits from Request, Request.JSON, and Request.JSONP: Request.Stocks. Created by Enrique Erne, this great MooTools class acts as...
You can use
gzip_comp_level 1
Sets a gzip compression level of a response. Acceptable values are in the range from 1 to 9.
Nice article, I also like to use
gzip_min_lengthparameter which reduces some overhead to gzip small responses.To test if gzip is enabled, run:
You should see
content-encoding: gzipFor production systems, I would suggest the use of
gzip_static.If you want to quickly test whether GZIP is enabled on your website or not use this tool: http://www.giftofspeed.com/gzip-test/
Saved me a lot of time. It also shows you the compression percentages and stuff (for some of my pages it was 70% or more! :-))
so gzip is only work on text type content?
I prefer this line as this enables for javascript too
This snippet made it so when I restarted nginx it failed. Not sure what the deal is. Just an FYI for anyone planning to follow those directions exactly.
nginx fails to restart because sometimes you’ll have gzip already enabled.
So removing the line “gzip on;” or commenting it with a # should do the job!
If you are using Ubuntu 10.04 just execute this command “sudo nginx”, and it shows you where is the problem if exist, my Nginx fails because this line “gzip on;”.
It seems Gzip already ON but no configuration was set.
Hey Brent,
That depends on where you put the code and how you did it.
Can you share your error So I can help.
I put the code into my website config file at
/etc/nginx/sites-enabled/foobar.com/and it works 100%Consider the addition of application/javascript. More in http://stackoverflow.com/questions/23939722/nginx-gzip-not-compressing-javascript-files
Thanks.. I thought it was because of my outdated nginx version. I updated it to latest version but still getting the same that all
.jsfiles were not gzip-compressed. Hence I added"application/x-javascript application/javascript text/javascript"all together. Thanks