GNU/Linux >> Znalost Linux >  >> Ubuntu

Jak nainstalovat Odoo 13 na Ubuntu 18.04

Odoo je populární open-source sada obchodních aplikací. Nabízí řadu aplikací, včetně CRM, e-Commerce, tvůrce webových stránek, fakturace, účetnictví, výroby, skladu, projektového managementu, inventáře a mnoho dalších, to vše hladce integrované.

Odoo lze nainstalovat několika způsoby v závislosti na případu použití a dostupných technologiích. Nejjednodušší a nejrychlejší způsob instalace Odoo je pomocí oficiálních repozitářů Odoo APT.

Instalace Odoo ve virtuálním prostředí nebo nasazení jako Dockercontainer vám umožní mít větší kontrolu nad nastavením systému a provozovat více verzí Odoo na stejném systému.

V této příručce vás provedeme instalací a nasazením Odoo 13 ve virtuálním prostředí Pythonu na Ubuntu 18.04. Stáhneme Odoo z jejich úložiště Github a použijeme Nginx jako reverzní proxy.

Předpoklady instalace #

Přihlaste se do svého Ubuntu jako uživatel sudo a aktualizujte mezipaměť Apt:

sudo apt update

Nainstalujte Git, Pip, Node.js a nástroje potřebné k vytvoření závislostí 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

Vytvoření systémového uživatele #

Vytvořte systémového uživatele, který bude spouštět Odoo, s názvem odoo13 s domovským adresářem /opt/odoo13 :

sudo useradd -m -d /opt/odoo13 -U -r -s /bin/bash odoo13

Jméno uživatele můžete nastavit na cokoliv chcete, pokud vytvoříte PostgreSQL uživatele se stejným jménem.

Instalace a konfigurace PostgreSQL #

Odoo používá PostgreSQL jako back-end databáze. Chcete-li nainstalovat PostgreSQL, spusťte následující příkaz:

sudo apt install postgresql

Po dokončení instalace vytvořte PostgreSQL uživatele se stejným jménem jako dříve vytvořený systémový uživatel, v našem případě to je odoo13 :

sudo su - postgres -c "createuser -s odoo13"

Instalace Wkhtmltopdf #

wkhtmltox balíček poskytuje sadu nástrojů příkazového řádku s otevřeným zdrojovým kódem, které dokážou vykreslit HTML do PDF a různých obrazových formátů. Abyste mohli tisknout zprávy ve formátu PDF, budete si muset nainstalovat wkhtmltopdf nářadí. Doporučená verze pro Odoo je 0.12.5 , který není dostupný ve výchozích úložištích Ubuntu 18.04.

Stáhněte si balíček pomocí následujícího wgetcommand:

wget https://github.com/wkhtmltopdf/wkhtmltopdf/releases/download/0.12.5/wkhtmltox_0.12.5-1.bionic_amd64.deb

Po dokončení stahování nainstalujte balíček zadáním:

sudo apt install ./wkhtmltox_0.12.5-1.bionic_amd64.deb

Instalace a konfigurace Odoo 13 #

Jak již bylo zmíněno, Odoo nainstalujeme ze zdroje v izolovaném virtuálním prostředí Pythonu.

Nejprve se změňte na uživatele „odoo13“:

sudo su - odoo13

Klonujte zdrojový kód Odoo 13 z GitHubu:

git clone https://www.github.com/odoo/odoo --depth 1 --branch 13.0 /opt/odoo13/odoo

Po dokončení stahování vytvořte nové virtuální prostředí Pythonu pro Odoo:

cd /opt/odoo13python3 -m venv odoo-venv

Aktivujte prostředí pomocí následujícího příkazu:

source odoo-venv/bin/activate

Nainstalujte všechny požadované moduly Pythonu pomocí pip3:

pip3 install wheelpip3 install -r odoo/requirements.txt
Pokud během instalace narazíte na nějakou chybu kompilace, ujistěte se, že všechny požadované závislosti jsou uvedeny v Installing Prerequisites sekce jsou nainstalovány.

Po dokončení deaktivujte prostředí zadáním:

deactivate

Vytvoříme nový adresář, který bude obsahovat doplňky třetích stran.

mkdir /opt/odoo13/odoo-custom-addons

Později tento adresář přidáme do addons_path parametr. Tento parametr definuje seznam adresářů, kde Odoo hledá moduly.

Přepněte zpět na uživatele sudo:

exit

Vytvořte konfigurační soubor s následujícím obsahem:

sudo nano /etc/odoo13.conf
/etc/odoo13.conf
[options]
; This is the password that allows database operations:
admin_passwd = my_admin_passwd
db_host = False
db_port = False
db_user = odoo13
db_password = False
addons_path = /opt/odoo13/odoo/addons,/opt/odoo13/odoo-custom-addons
Nezapomeňte změnit my_admin_passwd na něco bezpečnějšího.

Vytvoření souboru systémové jednotky #

Otevřete textový editor a vytvořte soubor servisní jednotky s názvem odoo13.service s následujícím obsahem:

sudo nano /etc/systemd/system/odoo13.service
/etc/systemd/system/odoo13.service
[Unit]
Description=Odoo13
Requires=postgresql.service
After=network.target postgresql.service

[Service]
Type=simple
SyslogIdentifier=odoo13
PermissionsStartOnly=true
User=odoo13
Group=odoo13
ExecStart=/opt/odoo13/odoo-venv/bin/python3 /opt/odoo13/odoo/odoo-bin -c /etc/odoo13.conf
StandardOutput=journal+console

[Install]
WantedBy=multi-user.target

Informujte systemd, že existuje nový soubor jednotky:

sudo systemctl daemon-reload

Spusťte službu Odoo a povolte její spuštění při spuštění spuštěním:

sudo systemctl enable --now odoo13

Ověřte stav služby:

sudo systemctl status odoo13

Výstup by měl vypadat nějak jako níže, což znamená, že služba Odoo je aktivní a běží.

● odoo13.service
   Loaded: loaded (/etc/systemd/system/odoo13.service; enabled; vendor preset: enabled)
   Active: active (running) since Sat 2019-10-19 20:06:23 UTC; 3s ago
 Main PID: 1860 (python3)
    Tasks: 4 (limit: 2362)
   CGroup: /system.slice/odoo13.service
           └─1860 /opt/odoo13/odoo-venv/bin/python3 /opt/odoo13/odoo/odoo-bin -c /etc/odoo13.conf

Chcete-li zobrazit zprávy zaznamenané službou Odoo, použijte příkaz níže:

sudo journalctl -u odoo13

Testování instalace #

Otevřete prohlížeč a zadejte:http://<your_domain_or_IP_address>:8069

Za předpokladu, že instalace proběhla úspěšně, objeví se obrazovka podobná následující:

Konfigurace Nginx jako proxy pro ukončení SSL #

Výchozí webový server Odoo obsluhuje provoz přes HTTP. Aby bylo nasazení Odoo bezpečnější, nakonfigurujeme Nginx jako ukončovací proxy SSL, který bude obsluhovat provoz přes HTTPS.

Proxy pro ukončení SSL je proxy server, který zpracovává šifrování/dešifrování SSL. To znamená, že ukončovací proxy (Nginx) zpracuje a dešifruje příchozí připojení TLS (HTTPS) a předá nešifrované požadavky interní službě (Odoo). Provoz mezi Nginx a Odoo nebude šifrován (HTTP).

Použití reverzního proxy vám poskytuje mnoho výhod, jako je vyrovnávání zátěže, ukončení SSL, ukládání do mezipaměti, komprese, poskytování statického obsahu a další.

Než budete pokračovat v této části, ujistěte se, že jste splnili následující předpoklady:

  • Název domény odkazující na IP vašeho veřejného serveru. Použijeme example.com .
  • Nginx nainstalován.
  • Certifikát SSL pro vaši doménu. Můžete si nainstalovat bezplatný certifikát Let’s Encrypt SSL.

Otevřete textový editor a vytvořte/upravte blok doménového serveru:

sudo nano /etc/nginx/sites-enabled/example.com.conf

Následující konfigurace nastavuje ukončení SSL, přesměrování HTTP na HTTPS, přesměrování z WWW na jiné než WWW, mezipaměť statických souborů a povolení komprese GZip.

/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;
}
Nezapomeňte nahradit example.com svou doménou Odoo a nastavit správnou cestu k souborům certifikátu SSL. Fragmenty použité v této konfiguraci jsou vytvořeny v této příručce.

Až budete hotovi, restartujte službu Nginx:

sudo systemctl restart nginx

Dále musíme říci Odoo, aby používal proxy. Chcete-li tak učinit, otevřete konfigurační soubor a přidejte následující řádek:

/etc/odoo13.conf
proxy_mode = True

Restartujte službu Odoo, aby se změny projevily:

sudo systemctl restart odoo13

V tomto okamžiku je nakonfigurován reverzní proxy a ke své instanci Odoo můžete přistupovat na adrese:https://example.com

Změna rozhraní vazby #

Tento krok je volitelný, ale je to dobrý bezpečnostní postup.

Ve výchozím nastavení server Odoo naslouchá portu 8069 na všech rozhraních. Chcete-li zakázat přímý přístup k instanci Odoo, můžete buď zablokovat port 8069 pro všechna veřejná rozhraní nebo přinutit Odoo, aby naslouchal pouze na místním rozhraní.

Nakonfigurujeme Odoo tak, aby naslouchalo pouze na 127.0.0.1 . Otevřete konfiguraci a na konec souboru přidejte následující dva řádky:

/etc/odoo13.conf
xmlrpc_interface = 127.0.0.1
netrpc_interface = 127.0.0.1

Uložte konfigurační soubor a restartujte server Odoo, aby se změny projevily:

sudo systemctl restart odoo13

Povolení vícenásobného zpracování #

Ve výchozím nastavení Odoo pracuje v režimu více vláken. Pro produkční nasazení se doporučuje přejít na multiprocessingový server, protože zvyšuje stabilitu a lépe využívá systémové prostředky.

Chcete-li povolit multiprocesing, musíte upravit konfiguraci Odoo a nastavit nenulový počet pracovních procesů. Počet pracovníků se vypočítá na základě počtu jader CPU v systému a dostupné paměti RAM.

Podle oficiální dokumentace Odoo pro výpočet počtu pracovníků a požadované velikosti paměti RAM můžete použít následující vzorce a předpoklady:

Výpočet počtu pracovníků

  • Teoretický maximální počet pracovníků =(system_cpus * 2) + 1
  • 1 pracovník může obsluhovat ~=6 souběžných uživatelů
  • Zaměstnanci Cron také vyžadují CPU

Výpočet velikosti paměti RAM

  • Budeme uvažovat, že 20 % všech požadavků jsou těžké požadavky a 80 % jsou lehčí. Velké požadavky využívají přibližně 1 GB paměti RAM, zatímco ty lehčí využívají přibližně 150 MB RAM
  • Potřebná RAM =number_of_workers * ( (light_worker_ratio * light_worker_ram_estimation) + (heavy_worker_ratio * heavy_worker_ram_estimation) )

Pokud nevíte, kolik CPU máte ve svém systému, použijte následující grep příkaz:

grep -c ^processor /proc/cpuinfo

Řekněme, že máte systém se 4 jádry CPU, 8 GB paměti RAM a 30 souběžnými uživateli Odoo.

  • 30 users / 6 = **5** (5 je teoretický počet potřebných pracovníků)
  • (4 * 2) + 1 = **9** ( 9 je teoretický maximální počet pracovníků)

Na základě výše uvedeného výpočtu můžete použít 5 pracovníků + 1 ​​pracovníka pro cron workera, což je celkem 6 pracovníků.

Vypočítejte spotřebu paměti RAM na základě počtu pracovníků:

  • RAM = 6 * ((0.8*150) + (0.2*1024)) ~= 2 GB of RAM

Výpočet ukazuje, že instalace Odoo bude potřebovat přibližně 2 GB RAM.

Chcete-li přepnout do režimu multiprocessingu, otevřete konfigurační soubor a připojte vypočítané hodnoty:

/etc/odoo13.conf
limit_memory_hard = 2684354560
limit_memory_soft = 2147483648
limit_request = 8192
limit_time_cpu = 600
limit_time_real = 1200
max_cron_threads = 1
workers = 5

Restartujte službu Odoo, aby se změny projevily:

sudo systemctl restart odoo13

Zbytek systémových prostředků využijí jiné služby, které na tomto systému běží. V této příručce jsme nainstalovali Odoo spolu s PostgreSQL a Nginx na stejný server. V závislosti na vašem nastavení mohou na vašem serveru běžet i další služby.


Ubuntu
  1. Jak nainstalovat Odoo 12 na Ubuntu 16.04

  2. Jak nainstalovat Odoo 13 na Ubuntu 18.04

  3. Jak nainstalovat Odoo 13 na Ubuntu 20.04

  1. Jak nainstalovat Odoo 10 na Ubuntu 16.04

  2. Jak nainstalovat Odoo 15 na Ubuntu 22.04

  3. Jak nainstalovat Odoo 13 na Ubuntu 20.04

  1. Jak nainstalovat Odoo na Ubuntu

  2. Jak nainstalovat Odoo 15 na Ubuntu 20.04

  3. Jak nainstalovat Odoo 11 na Ubuntu 16.04