This article is deprecated and no longer maintained.
Ubuntu 12.04 reached end of life (EOL) on April 28, 2017 and no longer receives security patches or updates.
This article may still be useful as a reference, but may not follow best practices or work on this or other Ubuntu releases. We strongly recommend using a recent article written for the version of Ubuntu you are using.
If you are currently operating a server running Ubuntu 12.04, we highly recommend upgrading or migrating to a supported version of Ubuntu:
Nginx is a free, Open Source Web server. It is much more lightweight than Apache and it can be used as the main web server software or be set up as a reverse proxy for Apache.
Before using this tutorial, you will need to SSH into your VPS, by typing into the terminal: ssh <user>@<server_ip>. The user will need to either be in root or have root privileges, otherwise the commands entered below may not work.
The packages that you will need to install are python-software-properties and software-properties-common (which is only necessary if you are running Ubuntu 12.10).
To install the first package dependency, python-software-properties, you will need to run the following command:
sudo apt-get install python-software-properties
If you are on Ubuntu 12.10, you should run the following command to install software-properties-common, which is another package that is necessary (without it, the add-apt-repository command used in Step Two will not be found).
sudo apt-get install software-properties-common
To ensure that our web server software is secure to run on a VPS, we will be using the latest ‘stable’ release.
If you are developing a nginx module, or if you need to use the “bleeding edge” version, you can replace the ‘stable’ version with the ‘development’ version. However I would not recommend doing this on a VPS, as there may be bugs.
Now that we have the latest stable package installed, we can now add the repository to install the latest version of nginx:
sudo add-apt-repository ppa:nginx/stable
Note: If this command still does not work (normally on 12.10), run the following command:
sudo apt-get install software-properties-common
This will add the repository to Ubuntu and fetches the repository’s key. This is to verify that the packages have not been interfered with since they have been built.
After adding a new repository, you will need to update the list:
sudo apt-get update
To install nginx or update the version you already have installed, run the following command:
sudo apt-get install nginx
You can check to see that nginx is running by either going to your VPS’ IP address/domain, or typing in:
service nginx status
This will tell you whether nginx is currently running.
If nginx is not running correctly, and/or prints out an error e.g. nginx: [emerg] bind() to [::]:80 failed (98: Address already in use), you can run:
netstat -tulpn
This will list all processes listening on ports. You should see something like this:
The highlighted number, the PID, is the number that you will use to kill the process. In this case, you would need to run kill -9 734. However the general code to copy into your terminal would be:
kill -9 xxxx
The phrase, “xxxx”, is the PID of the process you want to kill. After killing the process, you can try restarting nginx again by running:
service nginx start
Alternatively, the issue may be caused by the configuration accepting connections from both ipv4 and ipv6. In order to resolve this, edit out “listen [::]:80” in your default config file (/etc/nginx/sites-available/default) and any other server block config files that are in use.
sudo nano /etc/nginx/sites-available/default
The lines should look like this:
server {
listen 80;
#listen [::]:80 default_server;
You can view more information about the PPA release from: https://launchpad.net/~nginx/+archive/stable
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Can you help me?
I cannot get nginx to start. Every time I try to run it and I check the status, it says nginx is not running
Never mind! I followed the last bit of your tutorial, my file had ipv6_only=on and I removed it and it starts like a charm! Thanks!!!
@ceanelam Awesome!
Thanks for part about 12.10
I’ve been running into the nginx: [emerg] bind() to [::]:80 failed (98: Address already in use) error. Removed listen 80; and replaced it with listen [::]:80 ipv6only=on default_server; and the nginx will start. However, phpinfo doesn’t show it.
sudo netstat -tulpn
apache 127.0.0.1:8080 varnishd 192.241.231.x:80 varnishd 127.0.0.1:6082 nginx :::80
While everything appears to be started at the command line, how do I really know this is the optimal configuration?
Using listen 80; will not allow the nginx to start and gives the above error.
Any ideas?
@layne.heiny: It means you already have something listening on port 80 which is varnishd. You can have either nginx or varnish listening on port 80 - not both.
im getting the following:
could not access PID file for nginx
any ideas?
@pruett.kevin: Are you running the commands as root/through sudo?
I can confirm that these instructions work perfectly for Ubuntu 12.04 LTS as well.
This guide was extremely useful, thank you :)