We’ll show you, How to Install Odoo 10 on Ubuntu 16.04 with Nginx as a Reverse Proxy. Odoo is one of the most popular and most powerful Open Source ERP business software based on the Python programming language. In this tutorial, we will show you how to install Odoo 10 on an Ubuntu 16.04 VPS and show you how to configure Nginx as a reverse proxy for your Odoo 10 so you can access your Odoo application via a domain without typing Odoo’s port in the URL.
The installation of Odoo 10 on an Ubuntu 16.04 VPS should take no longer than 20 minutes if you follow the very easy steps described below.
1. Connect via SSH
First of all login to your Ubuntu 16.04 VPS via SSH as user root
ssh root@IP_address
2. Start a screen session
At the very beginning, it is best to start a screen session by executing the following command:
screen -U -S odoo
3. Update the OS packages
Update the OS packages on your virtual server using the following commands:
apt-get update && apt-get -y upgrade
Make sure to always keep your server up to date.
4. Download Install Script
In this tutorial, we are going to use the script from Yenthe Van Ginneken to install Odoo. You can download the script by running the following command:
wget https://raw.githubusercontent.com/Yenthe666/InstallScript/10.0/odoo_install.sh
Or, you can create a file and copy the following code to the new file (for example, ‘odoo_install.sh’).
nano odoo_install.sh
#!/bin/bash ################################################################################ # Script for installing Odoo V10 on Ubuntu 16.04, 15.04, 14.04 (could be used for other version too) # Author: Yenthe Van Ginneken #------------------------------------------------------------------------------- # This script will install Odoo on your Ubuntu 14.04 server. It can install multiple Odoo instances # in one Ubuntu because of the different xmlrpc_ports #------------------------------------------------------------------------------- # Make a new file: # sudo nano odoo-install.sh # Place this content in it and then make the file executable: # sudo chmod +x odoo-install.sh # Execute the script to install Odoo: # ./odoo-install ################################################################################ ##fixed parameters #odoo OE_USER="odoo" OE_HOME="/$OE_USER" OE_HOME_EXT="/$OE_USER/${OE_USER}-server" #The default port where this Odoo instance will run under (provided you use the command -c in the terminal) #Set to true if you want to install it, false if you don't need it or have it already installed. INSTALL_WKHTMLTOPDF="True" #Set the default Odoo port (you still have to use -c /etc/odoo-server.conf for example to use this.) OE_PORT="8069" #Choose the Odoo version which you want to install. For example: 10.0, 9.0, 8.0, 7.0 or saas-6. When using 'trunk' the master version will be installed. #IMPORTANT! This script contains extra libraries that are specifically needed for Odoo 10.0 OE_VERSION="10.0" # Set this to True if you want to install Odoo 10 Enterprise! IS_ENTERPRISE="False" #set the superadmin password OE_SUPERADMIN="admin" OE_CONFIG="${OE_USER}-server" ## ### WKHTMLTOPDF download links ## === Ubuntu Trusty x64 & x32 === (for other distributions please replace these two links, ## in order to have correct version of wkhtmltox installed, for a danger note refer to ## https://www.odoo.com/documentation/8.0/setup/install.html#deb ): WKHTMLTOX_X64=http://download.gna.org/wkhtmltopdf/0.12/0.12.1/wkhtmltox-0.12.1_linux-trusty-amd64.deb WKHTMLTOX_X32=http://download.gna.org/wkhtmltopdf/0.12/0.12.1/wkhtmltox-0.12.1_linux-trusty-i386.deb #-------------------------------------------------- # Update Server #-------------------------------------------------- echo -e "\n---- Update Server ----" sudo apt-get update sudo apt-get upgrade -y #-------------------------------------------------- # Install PostgreSQL Server #-------------------------------------------------- echo -e "\n---- Install PostgreSQL Server ----" sudo apt-get install postgresql -y echo -e "\n---- Creating the ODOO PostgreSQL User ----" sudo su - postgres -c "createuser -s $OE_USER" 2> /dev/null || true #-------------------------------------------------- # Install Dependencies #-------------------------------------------------- echo -e "\n---- Install tool packages ----" sudo apt-get install wget git python-pip gdebi-core -y echo -e "\n---- Install python packages ----" sudo apt-get install python-dateutil python-feedparser python-ldap python-libxslt1 python-lxml python-mako python-openid python-psycopg2 python-pybabel python-pychart python-pydot python-pyparsing python-reportlab python-simplejson python-tz python-vatnumber python-vobject python-webdav python-werkzeug python-xlwt python-yaml python-zsi python-docutils python-psutil python-mock python-unittest2 python-jinja2 python-pypdf python-decorator python-requests python-passlib python-pil -y python-suds echo -e "\n---- Install python libraries ----" sudo pip install gdata psycogreen ofxparse XlsxWriter echo -e "\n--- Install other required packages" sudo apt-get install node-clean-css -y sudo apt-get install node-less -y sudo apt-get install python-gevent -y #-------------------------------------------------- # Install Wkhtmltopdf if needed #-------------------------------------------------- if [ $INSTALL_WKHTMLTOPDF = "True" ]; then echo -e "\n---- Install wkhtml and place shortcuts on correct place for ODOO 10 ----" #pick up correct one from x64 & x32 versions: if [ "`getconf LONG_BIT`" == "64" ];then _url=$WKHTMLTOX_X64 else _url=$WKHTMLTOX_X32 fi sudo wget $_url sudo gdebi --n `basename $_url` sudo ln -s /usr/local/bin/wkhtmltopdf /usr/bin sudo ln -s /usr/local/bin/wkhtmltoimage /usr/bin else echo "Wkhtmltopdf isn't installed due to the choice of the user!" fi echo -e "\n---- Create ODOO system user ----" sudo adduser --system --quiet --shell=/bin/bash --home=$OE_HOME --gecos 'ODOO' --group $OE_USER #The user should also be added to the sudo'ers group. sudo adduser $OE_USER sudo echo -e "\n---- Create Log directory ----" sudo mkdir /var/log/$OE_USER sudo chown $OE_USER:$OE_USER /var/log/$OE_USER #-------------------------------------------------- # Install ODOO #-------------------------------------------------- echo -e "\n==== Installing ODOO Server ====" sudo git clone --depth 1 --branch $OE_VERSION https://www.github.com/odoo/odoo $OE_HOME_EXT/ if [ $IS_ENTERPRISE = "True" ]; then # Odoo Enterprise install! echo -e "\n--- Create symlink for node" sudo ln -s /usr/bin/nodejs /usr/bin/node sudo su $OE_USER -c "mkdir $OE_HOME/enterprise" sudo su $OE_USER -c "mkdir $OE_HOME/enterprise/addons" echo -e "\n---- Adding Enterprise code under $OE_HOME/enterprise/addons ----" sudo git clone --depth 1 --branch 10.0 https://www.github.com/odoo/enterprise "$OE_HOME/enterprise/addons" echo -e "\n---- Installing Enterprise specific libraries ----" sudo apt-get install nodejs npm sudo npm install -g less sudo npm install -g less-plugin-clean-css else echo -e "\n---- Create custom module directory ----" sudo su $OE_USER -c "mkdir $OE_HOME/custom" sudo su $OE_USER -c "mkdir $OE_HOME/custom/addons" fi echo -e "\n---- Setting permissions on home folder ----" sudo chown -R $OE_USER:$OE_USER $OE_HOME/* echo -e "* Create server config file" sudo cp $OE_HOME_EXT/debian/odoo.conf /etc/${OE_CONFIG}.conf sudo chown $OE_USER:$OE_USER /etc/${OE_CONFIG}.conf sudo chmod 640 /etc/${OE_CONFIG}.conf echo -e "* Change server config file" sudo sed -i s/"db_user = .*"/"db_user = $OE_USER"/g /etc/${OE_CONFIG}.conf sudo sed -i s/"; admin_passwd.*"/"admin_passwd = $OE_SUPERADMIN"/g /etc/${OE_CONFIG}.conf sudo su root -c "echo '[options]' >> /etc/${OE_CONFIG}.conf" sudo su root -c "echo 'logfile = /var/log/$OE_USER/$OE_CONFIG$1.log' >> /etc/${OE_CONFIG}.conf" if [ $IS_ENTERPRISE = "True" ]; then sudo su root -c "echo 'addons_path=$OE_HOME/enterprise/addons,$OE_HOME_EXT/addons' >> /etc/${OE_CONFIG}.conf" else sudo su root -c "echo 'addons_path=$OE_HOME_EXT/addons,$OE_HOME/custom/addons' >> /etc/${OE_CONFIG}.conf" fi echo -e "* Create startup file" sudo su root -c "echo '#!/bin/sh' >> $OE_HOME_EXT/start.sh" sudo su root -c "echo 'sudo -u $OE_USER $OE_HOME_EXT/openerp-server --config=/etc/${OE_CONFIG}.conf' >> $OE_HOME_EXT/start.sh" sudo chmod 755 $OE_HOME_EXT/start.sh #-------------------------------------------------- # Adding ODOO as a deamon (initscript) #-------------------------------------------------- echo -e "* Create init file" cat < ~/$OE_CONFIG #!/bin/sh ### BEGIN INIT INFO # Provides: $OE_CONFIG # Required-Start: \$remote_fs \$syslog # Required-Stop: \$remote_fs \$syslog # Should-Start: \$network # Should-Stop: \$network # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Enterprise Business Applications # Description: ODOO Business Applications ### END INIT INFO PATH=/bin:/sbin:/usr/bin DAEMON=$OE_HOME_EXT/odoo-bin NAME=$OE_CONFIG DESC=$OE_CONFIG # Specify the user name (Default: odoo). USER=$OE_USER # Specify an alternate config file (Default: /etc/openerp-server.conf). CONFIGFILE="/etc/${OE_CONFIG}.conf" # pidfile PIDFILE=/var/run/\${NAME}.pid # Additional options that are passed to the Daemon. DAEMON_OPTS="-c \$CONFIGFILE" [ -x \$DAEMON ] || exit 0 [ -f \$CONFIGFILE ] || exit 0 checkpid() { [ -f \$PIDFILE ] || return 1 pid=\`cat \$PIDFILE\` [ -d /proc/\$pid ] && return 0 return 1 } case "\${1}" in start) echo -n "Starting \${DESC}: " start-stop-daemon --start --quiet --pidfile \$PIDFILE \ --chuid \$USER --background --make-pidfile \ --exec \$DAEMON -- \$DAEMON_OPTS echo "\${NAME}." ;; stop) echo -n "Stopping \${DESC}: " start-stop-daemon --stop --quiet --pidfile \$PIDFILE \ --oknodo echo "\${NAME}." ;; restart|force-reload) echo -n "Restarting \${DESC}: " start-stop-daemon --stop --quiet --pidfile \$PIDFILE \ --oknodo sleep 1 start-stop-daemon --start --quiet --pidfile \$PIDFILE \ --chuid \$USER --background --make-pidfile \ --exec \$DAEMON -- \$DAEMON_OPTS echo "\${NAME}." ;; *) N=/etc/init.d/\$NAME echo "Usage: \$NAME {start|stop|restart|force-reload}" >&2 exit 1 ;; esac exit 0 EOF echo -e "* Security Init File" sudo mv ~/$OE_CONFIG /etc/init.d/$OE_CONFIG sudo chmod 755 /etc/init.d/$OE_CONFIG sudo chown root: /etc/init.d/$OE_CONFIG echo -e "* Change default xmlrpc port" sudo su root -c "echo 'xmlrpc_port = $OE_PORT' >> /etc/${OE_CONFIG}.conf" echo -e "* Start ODOO on Startup" sudo update-rc.d $OE_CONFIG defaults echo -e "* Starting Odoo Service" sudo su root -c "/etc/init.d/$OE_CONFIG start" echo "-----------------------------------------------------------" echo "Done! The Odoo server is up and running. Specifications:" echo "Port: $OE_PORT" echo "User service: $OE_USER" echo "User PostgreSQL: $OE_USER" echo "Code location: $OE_USER" echo "Addons folder: $OE_USER/$OE_CONFIG/addons/" echo "Start Odoo service: sudo service $OE_CONFIG start" echo "Stop Odoo service: sudo service $OE_CONFIG stop" echo "Restart Odoo service: sudo service $OE_CONFIG restart" echo "-----------------------------------------------------------"
5. Make the File Executable
After you create the file, in order to run the script we need to make the file executable with the following command:
chmod +x odoo_install.sh
6. Run the Script
Now we can run the script and wait until Odoo 10 is fully installed.
./odoo_install.sh
7. Configure Odoo
Edit the Odoo configuration file and set the master admin password:
nano /etc/odoo-server.conf
admin_passwd = UseStrongPassw0rd
Don’t forget to replace ‘UseStrongPassw0rd’ with an actual strong password.
8. Restart Odoo
Restart Odoo for the changes to take effect:
/etc/init.d/odoo-server restart
To access your Odoo, open your browser and navigate to http://your-server-IP:8069. Initially, you would be asked to create a new database.
Once the database is created, you will get redirected to the admin panel from where you can log in as the admin user.
After successfully logging in you can start using your Odoo 10 and configure it to your needs, install additional modules etc.
9. Setting up a Reverse Proxy
In order to access your Odoo application only by using your domain name, without the port number in the URL, we need to set up Nginx as a reverse proxy.
Before installing the Nginx web server, make sure that there is no other web server like Apache installed on the VPS. If Apache web server is running, stop it:
systemctl stop apache2
and remove it from your VPS:
apt-get purge apache2* apt autoremove
Now, run the following command to install Nginx:
apt-get install nginx
Once it is installed, start the web server and enable it to start on boot:
systemctl start nginx systemctl enable nginx
You can check if Nginx is successfully started using the following command:
systemctl status nginx
The output of the command above should be similar to this:
● nginx.service - A high performance web server and a reverse proxy server Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled) Active: active (running) Main PID: 4062 (nginx) CGroup: /system.slice/nginx.service ├─4062 nginx: master process /usr/sbin/nginx -g daemon on; master_process on ├─4063 nginx: worker process └─4064 nginx: worker process
You can also verify if Nginx is running, by accessing http://YOUR_IP
in your favorite web browser.
Create a new Nginx server block with the following content:
nano /etc/nginx/sites-available/my-odoo-site.com
upstream odoo { server 127.0.0.1:8069; } server { listen 80 default; server_name my-odoo-site.com; access_log /var/log/nginx/odoo.access.log; error_log /var/log/nginx/odoo.error.log; proxy_buffers 16 64k; proxy_buffer_size 128k; location / { proxy_pass http://odoo; proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto https; } location ~* /web/static/ { proxy_cache_valid 200 60m; proxy_buffering on; expires 864000; proxy_pass http://odoo; } }
Activate the server block by creating a symbolic link :
ln -s /etc/nginx/sites-available/my-odoo-site.com /etc/nginx/sites-enabled/my-odoo-site.com
Delete the default configuration:
rm -f /etc/nginx/sites-enabled/default
Test the Nginx configuration and restart nginx:
nginx -t service nginx restart
That’s it. If you followed all of the instructions properly you can now access your Odoo 10 using your domain name.
Of course you don’t have to install Odoo 10 on Ubuntu 16.04 with Nginx as a reverse proxy, if you use one of our managed cloud hosting services, in which case you can simply ask our expert Linux admins to to install Odoo 10 on Ubuntu 16.04 with Nginx as a reverse proxy, for you. They are available 24×7 and will take care of your request immediately.
PS. If you liked this post, on how to install Odoo 10 on Ubuntu 16.04 with Nginx as a reverse proxy, please share it with your friends on the social networks using the buttons on the left or simply leave a reply below. Thanks.
Thanks, dude, it’s very good help for me. very easy for me to understand. Book marked ‘LinuxCloudVPS -Odoo’
Thank you this worked out fine for me. Keen to learn how to apply subdomain filtering with Nginx as a proxy?
Unfortunately, we do not have a tutorial on this topic. Maybe we will have in the future. Meanwhile, you can refer to the Odoo community forums if you need any help with the setup.
Excellent tutorial, to the point. Thanks!
Is there any way we could add SLL through Let’s Encrypt to the domain? This would be a great final step so we could have a secure connection when using Odoo.
You can check our tutorial about How to install Let’s Encrypt on Ubuntu 16.04 with Nginx at
https://www.linuxcloudvps.com/blog/how-to-install-lets-encrypt-on-ubuntu-16-04-with-nginx/
Hi,
Thanks a lot for tutorial. I am new on linux and it is very helpful for me.
My host name is: svr.XYZ.com.tr
My DNS name: www.XYZ.com.tr
So, I have created file named /etc/nginx/sites-enabled/XYZ.com.tr (and I have tried as /etc/nginx/sites-enabled/www.XYZ.com.tr)
I change http://odoo to http://www.XYZ.com.tr and server_name as svr.XYZ.com.tr;
it does not worked for me. It stops nginx. When I delete file, nginx starts successfully.
ow I need to change file “/etc/nginx/sites-enabled/odoo.example.com” ?
The only thing you need to change in our example code for
/etc/nginx/sites-available/my-odoo-site.com
is theserver_name my-odoo-site.com
part to match your own domain name.If your nginx fails to start, you can run
nginx -t
to check for any configuration errors.Thanks a lot,
Very simple, and usefull