Odoo adalah perangkat lunak bisnis all-in-one paling populer di dunia. Ini menawarkan berbagai aplikasi bisnis termasuk CRM, situs web, e-Commerce, penagihan, akuntansi, manufaktur, gudang, manajemen proyek, inventaris, dan banyak lagi, semuanya terintegrasi dengan mulus.
Odoocan dapat diinstal dengan beberapa cara berbeda. Cara termudah dan tercepat untuk menginstal Odoo adalah dengan menggunakan repositori APT resmi mereka.
Jika Anda ingin memiliki lebih banyak fleksibilitas seperti menjalankan beberapa versi Odoo pada sistem yang sama, maka Anda dapat menggunakan komposisi buruh pelabuhan dan buruh pelabuhan atau menginstal Odoo di lingkungan virtual.
Tutorial ini mencakup langkah-langkah yang diperlukan untuk menginstal dan mengonfigurasi Odoo 12 untuk produksi menggunakan sumber Git dan lingkungan virtual Python pada sistem Ubuntu 18.04.
Sebelum memulai #
Masuk ke mesin Ubuntu Anda sebagai pengguna sudo dan perbarui sistem ke paket terbaru:
sudo apt update && sudo apt upgrade
Instal Git, Pip, Node.jsdan alat yang diperlukan untuk membangun dependensi Odoo:
sudo apt install git python3-pip build-essential wget python3-dev python3-venv python3-wheel libxslt-dev libzip-dev libldap2-dev libsasl2-dev python3-setuptools node-less
Buat pengguna Odoo #
Buat pengguna sistem baru untuk Odoo bernama odoo12
dengan direktori home /opt/odoo12
menggunakan perintah berikut:
sudo useradd -m -d /opt/odoo12 -U -r -s /bin/bash odoo12
Anda dapat menggunakan nama apa pun untuk pengguna Odoo Anda selama Anda membuat pengguna PostgreSQL dengan nama yang sama. Instal dan Konfigurasi PostgreSQL #
Instal PostgreSQLpackage dari repositori default Ubuntu:
sudo apt install postgresql
Setelah instalasi selesai, buat pengguna PostgreSQL dengan nama yang sama dengan pengguna sistem yang dibuat sebelumnya, dalam kasus kami yaitu odoo12
:
sudo su - postgres -c "createuser -s odoo12"
Instal Wkhtmltopdf #
wkhtmltox
package menyediakan seperangkat alat baris perintah sumber terbuka yang dapat membuat HTML menjadi PDF dan berbagai format gambar. Untuk mencetak laporan PDF, Anda memerlukan wkhtmltopdf
alat. Versi yang direkomendasikan untuk Odoo adalah 0.12.x
yang tidak tersedia di repositori resmi Ubuntu 18.04.
Unduh paket menggunakan wgetcommand berikut:
wget https://github.com/wkhtmltopdf/wkhtmltopdf/releases/download/0.12.5/wkhtmltox_0.12.5-1.bionic_amd64.deb
Setelah unduhan selesai, instal paket dengan mengetik:
sudo apt install ./wkhtmltox_0.12.5-1.bionic_amd64.deb
Instal dan Konfigurasi Odoo #
Kami akan menginstal Odoo dari repositori GitHub di dalam lingkungan virtual Python yang terisolasi.
Sebelum memulai proses instalasi, ubah ke user“odoo12”:
sudo su - odoo12
Mulailah dengan mengkloning kode sumber Odoo 12 dari repositori Odoo GitHub:
git clone https://www.github.com/odoo/odoo --depth 1 --branch 12.0 /opt/odoo12/odoo
Setelah kode sumber diunduh, buat lingkungan virtual Python baru untuk instalasi Odoo 12:
cd /opt/odoo12
python3 -m venv odoo-venv
Selanjutnya, aktifkan environment dengan perintah berikut:
source odoo-venv/bin/activate
Instal semua modul Python yang diperlukan dengan pip3:
Jika Anda menemukan kesalahan kompilasi selama penginstalan, pastikan Anda menginstal semua dependensi yang diperlukan yang tercantum dipip3 install wheel
pip3 install -r odoo/requirements.txt
Before you begin
bagian. Nonaktifkan lingkungan menggunakan perintah berikut:
deactivate
Buat direktori baru untuk add-on khusus:
mkdir /opt/odoo12/odoo-custom-addons
Beralih kembali ke pengguna sudo Anda:
exit
Selanjutnya, buat file konfigurasi, dengan menyalin contoh file konfigurasi yang disertakan:
sudo cp /opt/odoo12/odoo/debian/odoo.conf /etc/odoo12.conf
Buka file dan edit sebagai berikut:
sudo nano /etc/odoo12.conf
/etc/odoo12.conf[options]
; This is the password that allows database operations:
admin_passwd = my_admin_passwd
db_host = False
db_port = False
db_user = odoo12
db_password = False
addons_path = /opt/odoo12/odoo/addons,/opt/odoo12/odoo-custom-addons
Jangan lupa ganti my_admin_passwd
untuk sesuatu yang lebih aman. Buat File Unit Sistem #
Untuk menjalankan Odoo sebagai layanan, kita perlu membuat file unit layanan di /etc/systemd/system/
direktori.
Buka editor teks Anda dan rekatkan konfigurasi berikut:
sudo nano /etc/systemd/system/odoo12.service
/etc/systemd/system/odoo12.service[Unit]
Description=Odoo12
Requires=postgresql.service
After=network.target postgresql.service
[Service]
Type=simple
SyslogIdentifier=odoo12
PermissionsStartOnly=true
User=odoo12
Group=odoo12
ExecStart=/opt/odoo12/odoo-venv/bin/python3 /opt/odoo12/odoo/odoo-bin -c /etc/odoo12.conf
StandardOutput=journal+console
[Install]
WantedBy=multi-user.target
Beri tahu systemd bahwa ada file unit baru dan mulai layanan Odoo dengan menjalankan:
sudo systemctl daemon-reload
sudo systemctl start odoo12
Periksa status layanan dengan perintah berikut:
sudo systemctl status odoo12
Outputnya akan terlihat seperti di bawah ini yang menunjukkan bahwa layanan Odoo aktif dan berjalan.
* odoo12.service - Odoo12
Loaded: loaded (/etc/systemd/system/odoo12.service; disabled; vendor preset: enabled)
Active: active (running) since Tue 2018-10-09 14:15:30 PDT; 3s ago
Main PID: 24334 (python3)
Tasks: 4 (limit: 2319)
CGroup: /system.slice/odoo12.service
`-24334 /opt/odoo12/odoo-venv/bin/python3 /opt/odoo12/odoo/odoo-bin -c /etc/odoo12.conf
Aktifkan layanan Odoo untuk dimulai secara otomatis saat boot:
sudo systemctl enable odoo12
Jika Anda ingin melihat pesan yang dicatat oleh layanan Odoo, Anda dapat menggunakan perintah di bawah ini:
sudo journalctl -u odoo12
Uji Instalasi #
Buka browser Anda dan ketik:http://<your_domain_or_IP_address>:8069
Dengan asumsi instalasi berhasil, layar yang mirip dengan berikut akan muncul:
Konfigurasikan Nginx sebagai Proksi Penghentian SSL #
Pastikan Anda telah memenuhi prasyarat berikut sebelum melanjutkan ke bagian ini:
- Nama domain yang menunjuk ke IP server publik Anda. Dalam tutorial ini kita akan menggunakan
example.com
. - Nginx terpasang.
- Sertifikat SSL untuk domain Anda. Anda dapat menginstal sertifikat SSL Let's Encrypt gratis.
Server web default Odoo melayani lalu lintas melalui HTTP. Untuk membuat penerapan Odoo kami lebih aman, kami akan mengonfigurasi Nginx sebagai proxy terminasi SSL yang akan melayani lalu lintas melalui HTTPS.
Proxy terminasi SSL adalah server proxy yang menangani enkripsi/dekripsi SSL. Ini berarti bahwa proxy terminasi (Nginx) kami akan menangani dan mendekripsi koneksi TLS masuk (HTTPS), dan akan meneruskan permintaan tidak terenkripsi ke layanan internal kami (Odoo) sehingga lalu lintas antara Nginx dan Odoo tidak akan dienkripsi (HTTP).
Menggunakan proxy terbalik memberi Anda banyak manfaat seperti Load Balancing, Terminasi SSL, Caching, Kompresi, Melayani Konten Statis, dan banyak lagi.
Dalam contoh ini kita akan mengonfigurasi Penghentian SSL, pengalihan HTTP ke HTTPS, pengalihan WWW ke non-WWW, cache file statis dan mengaktifkan GZipcompression.
Buka editor teks Anda dan buat file berikut:
sudo nano /etc/nginx/sites-enabled/example.com.conf
/etc/nginx/sites-enabled/example.com.conf# Odoo servers
upstream odoo {
server 127.0.0.1:8069;
}
upstream odoochat {
server 127.0.0.1:8072;
}
# HTTP -> HTTPS
server {
listen 80;
server_name www.example.com example.com;
include snippets/letsencrypt.conf;
return 301 https://example.com$request_uri;
}
# WWW -> NON WWW
server {
listen 443 ssl http2;
server_name www.example.com;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
include snippets/ssl.conf;
include snippets/letsencrypt.conf;
return 301 https://example.com$request_uri;
}
server {
listen 443 ssl http2;
server_name example.com;
proxy_read_timeout 720s;
proxy_connect_timeout 720s;
proxy_send_timeout 720s;
# Proxy headers
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Real-IP $remote_addr;
# SSL parameters
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
include snippets/ssl.conf;
include snippets/letsencrypt.conf;
# log files
access_log /var/log/nginx/odoo.access.log;
error_log /var/log/nginx/odoo.error.log;
# Handle longpoll requests
location /longpolling {
proxy_pass http://odoochat;
}
# Handle / requests
location / {
proxy_redirect off;
proxy_pass http://odoo;
}
# Cache static files
location ~* /web/static/ {
proxy_cache_valid 200 90m;
proxy_buffering on;
expires 864000;
proxy_pass http://odoo;
}
# Gzip
gzip_types text/css text/less text/plain text/xml application/xml application/json application/javascript;
gzip on;
}
Jangan lupa untuk mengganti example.com dengan domain Odoo Anda dan mengatur jalur yang benar ke file sertifikat SSL. Cuplikan yang digunakan dalam konfigurasi ini dibuat dalam panduan ini. Setelah selesai, restart layanan Nginx dengan:
sudo systemctl restart nginx
Selanjutnya, kita perlu memberi tahu Odoo bahwa kita akan menggunakan proxy. Untuk melakukannya, buka file konfigurasi dan tambahkan baris berikut:
/etc/odoo12.confproxy_mode = True
Mulai ulang layanan Odoo agar perubahan diterapkan:
sudo systemctl restart odoo12
Pada titik ini, server Anda telah dikonfigurasi dan Anda dapat mengakses instans Odoo Anda di:https://example.com
Ubah antarmuka pengikatan #
Langkah ini opsional, tetapi merupakan praktik keamanan yang baik.
Secara default, server Odoo mendengarkan port 8069 di semua antarmuka. Jika Anda ingin menonaktifkan akses langsung ke instans Odoo Anda, Anda dapat memblokir port 8069
untuk semua antarmuka publik atau memaksa Odoo untuk mendengarkan hanya di antarmuka lokal.
Dalam panduan ini kami akan mengonfigurasi Odoo untuk mendengarkan hanya di 127.0.0.1
. Buka konfigurasi tambahkan dua baris berikut di akhir file:
xmlrpc_interface = 127.0.0.1
netrpc_interface = 127.0.0.1
Simpan file konfigurasi dan mulai ulang server Odoo agar perubahan diterapkan:
sudo systemctl restart odoo12
Aktifkan Multiprosesor #
Secara default, Odoo bekerja dalam mode multithreading. Untuk penerapan produksi, disarankan untuk beralih ke server multiprosesor karena ini meningkatkan stabilitas, dan memanfaatkan sumber daya sistem dengan lebih baik. Untuk mengaktifkan multiprosesor, kita perlu mengedit konfigurasi Odoo dan menyetel jumlah proses pekerja yang bukan nol.
Jumlah pekerja dihitung berdasarkan jumlah inti CPU dalam sistem dan memori RAM yang tersedia.
Menurut dokumentasi resmi Odoo untuk menghitung jumlah pekerja dan ukuran memori RAM yang diperlukan, kami akan menggunakan rumus dan asumsi berikut:
Penghitungan jumlah pekerja
- jumlah maksimum teoritis pekerja =(system_cpus * 2) + 1
- 1 pekerja dapat melayani ~=6 pengguna bersamaan
- Pekerja Cron juga membutuhkan CPU
Penghitungan ukuran memori RAM
- Kami akan mempertimbangkan bahwa 20% dari semua permintaan adalah permintaan yang berat, sedangkan 80% adalah permintaan yang lebih ringan. Permintaan berat menggunakan sekitar 1 GB RAM sedangkan yang lebih ringan menggunakan sekitar 150 MB RAM
- RAM yang dibutuhkan =
number_of_workers * ( (light_worker_ratio * light_worker_ram_estimation) + (heavy_worker_ratio * heavy_worker_ram_estimation) )
Jika Anda tidak tahu berapa banyak CPU yang Anda miliki di sistem Anda, Anda dapat menggunakan perintah berikut:
grep -c ^processor /proc/cpuinfo
Katakanlah kita memiliki sistem dengan 4 inti CPU, memori RAM 8 GB, dan 30 pengguna Odoo secara bersamaan.
30 users / 6 = **5**
(5 adalah jumlah teoritis pekerja yang dibutuhkan )(4 * 2) + 1 = **9**
( 9 adalah jumlah maksimum teoritis pekerja)
Berdasarkan perhitungan di atas kita dapat menggunakan 5 pekerja + 1 pekerja untuk pekerja cron yang berjumlah 6 pekerja.
Hitung konsumsi memori RAM berdasarkan jumlah pekerja:
RAM = 6 * ((0.8*150) + (0.2*1024)) ~= 2 GB of RAM
Perhitungan di atas menunjukkan kepada kita bahwa instalasi Odoo kita akan membutuhkan sekitar 2GB RAM.
Untuk beralih ke mode multiproses, buka file konfigurasi dan tambahkan baris berikut:
/etc/odoo12.conflimit_memory_hard = 2684354560
limit_memory_soft = 2147483648
limit_request = 8192
limit_time_cpu = 600
limit_time_real = 1200
max_cron_threads = 1
workers = 5
Mulai ulang layanan Odoo agar perubahan diterapkan:
sudo systemctl restart odoo12
Sisa sumber daya sistem akan digunakan oleh layanan lain yang berjalan di sistem ini. Dalam panduan ini kami menginstal Odoo bersama dengan PostgreSQL dan Nginx di server yang sama dan tergantung pada pengaturan Anda, Anda mungkin juga memiliki layanan lain yang berjalan di server Anda.