Odoo is a business software that comes packed with CRM, e-commerce, billing, accounting, project management, manufacturing, warehouse, and inventory apps. The Community version is an open-source version, while the Enterprise version adds proprietary features and services to the Community edition.
At FOSS Linux, we are focused on open-source apps, so in this tutorial, we are going to install and configure the Oddo community version on CentOS.
Installing Odoo 12 on CentOS
We shall execute commands using the root user.
1. Update System
yum update
data:image/s3,"s3://crabby-images/45f5e/45f5ec2ccd07ee50ba9022be0b300a97f6483d73" alt="Update Server"
Update Server
The server will ask to update or no. Type “y” and hit enter. It will get some time to update the system.
data:image/s3,"s3://crabby-images/c06e9/c06e91ac6562a32f6395bb76dad4b91216f1dcc7" alt="Update Completed"
Update Completed
2. Configure Needed Repositories
Enable Epel repository:
yum install epel-release
data:image/s3,"s3://crabby-images/74d29/74d29946212071cbca2cbbf1faff95db1c60c479" alt="Add EPEL Repository"
Add EPEL Repository
Enable the Software Collections (SCL) repository:
yum install centos-release-scl
Enable SCL Repository
3. Install Python 3.6 and Dependencies
yum install rh-python36
data:image/s3,"s3://crabby-images/55bd7/55bd71daffcab0b826bba25b8593e118fe4c538b" alt="Install Python 3.6"
Install Python 3.6
Install needed dependencies.
yum install bzip2-devel freetype-devel nodejs-less libxslt-devel openldap-devel libjpeg-devel gcc
data:image/s3,"s3://crabby-images/79ca6/79ca6fc4ce2c8839dd8332ec3d5d8c20fe4e82f8" alt="Install Dependencies"
Install Dependencies
4. Create Odoo User
useradd -m -U -r -d /opt/odoo -s /bin/bash odoousr
data:image/s3,"s3://crabby-images/31039/310398ecc38e9a593b9afab8627f9cf3413241b3" alt="Create Odoo User"
Create Odoo User
5. Install and configure PostgreSQL
Check repositories from the official site and install the Postgres repository for Centos 7 64bit.
rpm -Uvh https://yum.postgresql.org/11/redhat/rhel-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
data:image/s3,"s3://crabby-images/2878e/2878e1bcf6eed974ed3c6b7d6c00b7a2a6d60650" alt="Configure PostgreSQL Repository"
Configure PostgreSQL Repository
Now Install PostgreSQL 11 server.
yum install postgresql11-server
data:image/s3,"s3://crabby-images/eae87/eae87e69d7542838064a75ea98dba16d5faa3586" alt="Install PostgreSQL 11"
Install PostgreSQL 11
Initialize PGDATA
Initialize the database using the below command. It should create a data directory and other configuration files on the system.
/usr/pgsql-11/bin/postgresql-11-setup initdb
data:image/s3,"s3://crabby-images/aedb0/aedb0fe29faca54550f9a16becbe76fcef950048" alt="Initialize PGDATA"
Initialize PGDATA
Now, check PostgreSQL Service Status.
systemctl status postgresql-11.service
data:image/s3,"s3://crabby-images/9b45e/9b45e089badb3e7ba227ad6f44aae6fdc92981ac" alt="PostgreSQL Service Status"
PostgreSQL Service Status
If service is not started. Run the following command to start service:
systemctl start postgresql-11.service
Enable service on the system boot.
systemctl enable postgresql-11.service
data:image/s3,"s3://crabby-images/ef906/ef906a505e061e52f1b431736f70c93c5c01259b" alt="Enable Service OnBoot"
Enable Service OnBoot
Need to Check and Verify PostgreSQL Installation.
su - postgres -c "psql"
data:image/s3,"s3://crabby-images/c7d6a/c7d6ac6eccd08d565a1f7baebfc33e776718eea4" alt="Check Installation"
Check Installation
If you want, you can create a password too.
\password postgres
data:image/s3,"s3://crabby-images/27c23/27c233762dbc638aad6c2d1ae11e51032a40307c" alt="Configure PostgreSQL Password."
Configure PostgreSQL Password
Create a PostgreSQL user.
su - postgres -c "createuser -s odoousr"
data:image/s3,"s3://crabby-images/843e7/843e7656b6bf17bf555adc144eb0bd771eeb3cf4" alt="Create PostgreSQL User"
Create PostgreSQL User
6. Install Wkhtmltopdf
It is an open-source tool that Odoo uses to make HTML in PDF formats so that it can print PDF reports.
wget https://downloads.wkhtmltopdf.org/0.12/0.12.5/wkhtmltox-0.12.5-1.centos7.x86_64.rpm
data:image/s3,"s3://crabby-images/9bc3b/9bc3baf096a44fa5efc0753da13d16a39dd28cad" alt="Download Package"
Download Package
“wget” is not available. need to install it first
yum install wget -y
Install the downloaded package using below command:
yum localinstall wkhtmltox-0.12.5-1.centos7.x86_64.rpm
data:image/s3,"s3://crabby-images/3fb43/3fb439d1cfc4740c673080202d428e65b8e63c71" alt="Install wkhtmltopdf Package"
Install wkhtmltopdf Package
7. Install and configure Odoo 12
Git is not installed on your system Install git first.
yum install git -y
Change user to odoo user:
su - odoousr
Now we are going to clone odoo 12 from its repository. We are going to download it to the “/opt/odoo/odoo12” directory.
git clone https://www.github.com/odoo/odoo --depth 1 --branch 12.0 /opt/odoo/odoo12
data:image/s3,"s3://crabby-images/f2e6c/f2e6c15e24d75a5ac9cb1ec154f729689903d1e6" alt="Git Clone Odoo12"
Git Clone Odoo12
To enable python36, run the following command:
scl enable rh-python36 bash
8. Create a new virtual environment
Go to odoo directory:
cd /opt/odoo
Run the below command to create an environment.
python3 -m venv odoo12-venv
Activate the environment:
source odoo12-venv/bin/activate
data:image/s3,"s3://crabby-images/fa7ef/fa7ef3ea8c545f84bfb05a3a3640863fd9185c20" alt="Create Virtual Environment"
Create Virtual Environment
Upgrade pip:
pip install --upgrade pip
data:image/s3,"s3://crabby-images/bf4f0/bf4f06118395f6859f3eeba15033131b7b842aae" alt="Upgrade Pip"
Upgrade Pip
Install the Wheel library, followed by all the required Python modules.
pip3 install wheel
pip3 install -r odoo12/requirements.txt
data:image/s3,"s3://crabby-images/5b3a0/5b3a0b2eb743caeceaf78a6eb6814e54b6f675ec" alt="Install Required Python Modules"
Install Required Python Modules
After installation is complete, Deactivate the virtual environment and return to the root user.
data:image/s3,"s3://crabby-images/ac19d/ac19d3144270bd9b1bac5056c0265206702d9200" alt="Return to root"
Return to root
9. Other configurations for Odoo12
Create a directory for custom modules.
mkdir /opt/odoo/odoo12-custom-addons
chown odoousr: /opt/odoo/odoo12-custom-addons
data:image/s3,"s3://crabby-images/355cb/355cb2d5c065148ff7da2e1046fa736e04466ed7" alt="Folder For Custom Modules"
Folder For Custom Modules
Create a configuration file for the Odoo12.
vim /etc/odoo12.conf
If vim is not available, you should install it first, or you can use any editor of your choice.
yum install vim
Add the following lines to file:
[options] ; This is the password that allows database operations: admin_passwd = Foss@343fd<?Linux db_host = False db_port = False db_user = odoousr db_password = False addons_path = /opt/odoo/odoo12/addons,/opt/odoo/odoo12-custom-addons logfile = /var/log/odoo12/odoo.log
data:image/s3,"s3://crabby-images/23760/23760aa338ef901d0b26fb265463e360bd08bfcc" alt="Configurations"
Configurations
Save, and exit. Then create a log folder and grant permission to it.
mkdir -p /var/log/odoo12
chown -R odoousr: /var/log/odoo12
10. Manually start odoo12
Now start service and check whether it is working correctly. Change the user and then start command.
su - odoousr
/usr/bin/scl enable rh-python36 -- /opt/odoo/odoo12-venv/bin/python3 /opt/odoo/odoo12/odoo-bin -c /etc/odoo12.conf
data:image/s3,"s3://crabby-images/2caae/2caae41febe64a2bb94f0e51afd6aaba0e0b0fbd" alt="Start Service"
Start Service
Check Odoo12 port is up and running. Then open another terminal and run below command:
netstat -tunlp | grep 8069
Odoo12 Port
11. Configure firewall
Check firewall status.
systemctl status firewalld
data:image/s3,"s3://crabby-images/dd0dc/dd0dcef87dac338ed8f059275a77ce342e6c3075" alt="Firewall Status"
Firewall Status
If the service has not started, start it using the following command:
systemctl start firewalld
Add firewall rules and reload firewall:
firewall-cmd --zone=public --permanent --add-service=http
firewall-cmd --zone=public --permanent --add-port=8069/tcp
systemctl reload firewalld
data:image/s3,"s3://crabby-images/ca4b1/ca4b184c3471824948af878044e6329d6decd1d3" alt="Firewall Rules"
Firewall Rules
12. Browse Application
http://Ip or domain name:8069
You will get the Start page.
data:image/s3,"s3://crabby-images/cd1fc/cd1fc55275a3de17cd05fbf5c725c7caa7dddd27" alt="Start Page"
Start Page
If you get a “Service Unavailable” message, temporary change Selinux mode.
setenforce 0
13. Configure Odoo12 run as a Service
Create a systemd file and add the following content to the file:
vim /etc/systemd/system/odoo12.service
[Unit] Description=Odoo12 Requires=postgresql-11.service After=network.target postgresql-11.service [Service] Type=simple SyslogIdentifier=odoo12 PermissionsStartOnly=true User=odoousr Group=odoousr ExecStart=/usr/bin/scl enable rh-python36 -- /opt/odoo/odoo12-venv/bin/python3 /opt/odoo/odoo12/odoo-bin -c /etc/odoo12.conf StandardOutput=journal+console [Install] WantedBy=multi-user.target
Save, and exit.
Reload systemctl daemon.
systemctl daemon-reload
14. Now stop previously started odoo12
Check process.
ps -aux | grep odoo
Odoo ProcessKill process.
kill -9 28416 28417 28420
Make sure to replace process IDs with yours.
15. Now start odoo12 service
systemctl start odoo12
Check status.
systemctl status odoo12
data:image/s3,"s3://crabby-images/ed8bc/ed8bc98737de316a2d9f8c2134035cc632ccb990" alt="Odoo Service Status"
Odoo Service Status
Monitor the log file using the following command:
tail -f /var/log/odoo12/odoo.log
Check status and enable Odoo service on system boot.
systemctl enable odoo12
16. Browse the web site and continue
http://Ip Or Domain name:8069
Add a Master password, database name, and other details.
data:image/s3,"s3://crabby-images/1fc04/1fc043a7eea8dfc21450f5092134e4bd416a8ece" alt="Odoo DB Creation"
Odoo DB Creation
Then click “create database” (Here I added demo data too). You should be redirected to the welcome page.
data:image/s3,"s3://crabby-images/38b92/38b924b0b51a51b69835d042c374c24d6e5b8396" alt="Welcome Page"
Welcome Page
After sign out from the above page, you should go to the login page.
data:image/s3,"s3://crabby-images/b3c40/b3c40a288a9b6168bbefc3df5246df30bd8614f1" alt="Login Page"
Login Page
That’s all about the installation of the latest Odoo 12 on Centos 7. I hope you enjoyed the tutorial.