This how-to describe a minimal Odoo installation on Centos or RedHat. It can be easily adapted to any Linux distribution (Debian, Ubuntu, SuSE, Mandriva, Arch Linux, …). This a simple, easy and rock-solid way to install Odoo for small groups.
An eye on the doc
First steps — just for those who forget something
Create one user account, add the user to the wheel group. This will let you use sudo. Add your ssh-key, from local to remote :
$ ssh-copy-id -i ~/.ssh/id_rsa.pub user@IP
Install yum utilities and some of your favorite’s command-line tools. Yum utilities comes with the useful yum-config-manager. Even if you don’t use it, it can show you the whole params of each repositories. Here below I install Lynx text browser to read html pages in Midnight-Commander.
# yum install yum-utils # yum install nano mlocate screen wget mc lynx unzip
Install postgresql-server and start it, otherwise Odoo will not be able to create odoo user.
# yum install postgresql-server # postgresql-setup initdb $ systemctl start postgresql
Enable EPEL repository
We need complementary packages, not provided by distribution repository. Basicaly we have two solutions :
- add Software Collections packages
- add new repositories
Software Collections are installed in parallel from distribution’s package. Our server will only run Odoo, so there is no need to separate packages. It is easier to add repositories.
EPEL is Extra Packages for Enterprise Linux. The epel-release package is included in the CentOS Extras repository that is enabled by default. One just need to type :
# yum install epel-release
To clear any cached information, and to make sure the changes are immediately recognized :
# yum clean all # yum update
If you need, install some more utilities from Epel. I like p7zip.
Add Odoo repository
Odoo provide package. You can download it or install from nightly builds repository (both are the same).
# yum-config-manager --add-repo=https://nightly.odoo.com/10.0/nightly/rpm/odoo.repo # yum clean all # yum update # yum install odoo $ systemctl start odoo
Download wkhtmltopdf and install it. Do not use the package from Epel repository as it can’t handle headers and footers.
A bit of testing
Stop Firewalld and connect to http://[your-hostname]:8069/ default login/password is admin/admin. Create a dummy or template database. Don’t install applications, just configure Administrator account :
in configuration menu, go to users and change Administrator’s timezone, email, and choose a solid password. You will be disconnected. Login with the new params. If it’ ok, disconnect again and stop Odoo server. Restart Firewalld to protect your web server.
Odoo master password, Firewalld, fail2ban, services.
# nano /etc/odoo/odoo.conf [options] ; This is the password that allows database operations: admin_passwd = whatever big and solid db_host = False db_port = False db_user = odoo db_password = False addons_path = /usr/lib/python2.7/site-packages/odoo/addons
Need to open the port on Firewalld. We create Odoo service that we will enable on the firewall public zone.
# nano /etc/firewalld/services/odoo.xml <?xml version="1.0" encoding="utf-8"?> <service> <short>Odoo</short> <description> Open Odoo default port. </description> <port protocol="tcp" port="8069"/> </service>
Enable Odoo on public zone ; the –permanent option needs to be the first option for all permanent calls (1). Don’t forget to reload the firewall !
# firewall-cmd --permanent --zone=public --add-service=odoo # firewall-cmd --reload
Similarly, enable http and https services:
# firewall-cmd --permanent --zone=public --add-service=http # firewall-cmd --permanent --zone=public --add-service=https #firewall-cmd --reload
Install and start Fail2ban, then enable services on startup :
# systemctl enable postgresql # systemctl enable odoo # systemctl enable fail2ban
And start Odoo again. Connect to Odoo.
A template database
Now we will setup a « template » database. Something with all the basics that we need. Start with security and backup :
Install Letsencrypt and Database Auto-Backup module from OCA’s server tools repository. Download zip from https://github.com/OCA/server-tools/
Setup auto-backup. Test it : make a backup, get it, try to restore.
You will certainly need to increase the time-out on your server. Beware that as long as you db grows, the backup grows as well. But the heavier part will certainly be the multiples files (images, documents, …) that Odoo will generates for you.
Use Letsencrypt to get an SSL certificate as soon as domains are moved on your server.
Web environment ribbon is a very useful utility for those who works on several Odoo instances. You will got a red ribbon on the top left corner in every page (ribbon name and color can be changed).
Add users, configure company, email servers, etc.
Backup or duplicate your database with Odoo database manager. You will leave your first copy untouched. It will be used as a template. For further installations, just duplicate your template and install everything you need.
If you want a server admin panel
Avoid extra dependencies (PHP, MySQL, …). If you can, choose Perl based or Python based software if possible.
- Webmin use Perl, it have a lots of modules, is actively developped, but old ;
- BlueOnyx is built with Java and Perl, based on a product developped by Cobalt, it’s solid but a bit old ;
- Ajenti use Python but does only a few things so far, it is recent and light ;
- A few other ones doesn’t need MySQL, but use PHP.
Depending on what you need you will configure Postgresql, Odoo and Nginx web server for speed and efficiency.