Ubuntu 20服務器系統中安裝配置Odoo 13的流程
作者:admin | 時間:2020-11-18 21:04:12

Ubuntu服務器上的Python虛擬環境中安裝和配置Odoo 13,我們將從其Github存儲庫中下載Odoo,并使用Nginx作為反向代理??梢愿鶕美涂捎眉夹g以多種方式安裝Odoo,安裝Odoo的最簡單,最快的方法是使用官方的Odoo APT存儲庫。在虛擬環境中安裝Odoo或作為Docker容器進行部署,使您可以更好地控制系統設置,并在同一系統上運行多個Odoo版本。



一、安裝先決條件及創建系統用戶

1、安裝先決條件

以sudo用戶身份登錄到Ubuntu 18.04,并更新Apt緩存:

sudo apt update

安裝Git、Pip、Node.js和構建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

2、創建系統用戶

創建一個將運行Odoo的系統用戶,名為oodo13,主目錄為/opt/odoo13:

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

您可以將用戶名設置為任何所需的名稱,只要您創建具有相同名稱的PostgreSQL用戶即可。

 

二、安裝和配置PostgreSQL及安裝Wkhtmltopdf

1、安裝和配置PostgreSQL

Odoo使用PostgreSQL作為數據庫后端,要安裝PostgreSQL,請運行以下命令:

sudo apt install postgresql

安裝完成后,請使用與先前創建的系統用戶相同的名稱創建一個PostgreSQL用戶,在本例中為odoo13:

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

2、安裝Wkhtmltopdf

wkhtmltox軟件包提供了一組開源命令行工具,可以將HTML渲染為PDF和各種圖像格式,為了能夠打印PDF報告,您需要安裝wkhtmltopdf工具,Odoo的推薦版本為0.12.5,默認的Ubuntu 18.04存儲庫中不提供該版本。請到 https://github.com/wkhtmltopdf/wkhtmltopdf/releases/ 中下載wkhtmltox_0.12.5-1.bionic_amd64.deb。

下載完成后,輸入以下命令安裝軟件包:

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

 

三、安裝和配置Odoo 13

如前所述,我們將從一個隔離的Python虛擬環境中的源代碼安裝Odoo。

首先,更改為用戶“odoo13”:

sudo su - odoo13

從GitHub存儲庫克隆Odoo 13源代碼:

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

下載完成后,為Odoo創建一個新的Python虛擬環境:

cd /opt/odoo13

python3 -m venv odoo-venv

使用以下命令激活環境:

source odoo-venv/bin/activate

使用pip3安裝所有必需的Python模塊:

pip3 install wheel

pip3 install -r odoo/requirements.txt

如果在安裝過程中遇到任何編譯錯誤,請確保已安裝“安裝先決條件”部分中列出的所有必需依賴項。

完成后,通過鍵入以下命令停用環境:

deactivate

我們將創建一個新目錄,其中將包含第三方插件:

mkdir /opt/odoo13/odoo-custom-addons

稍后,我們將此目錄添加到addons_path參數,此參數定義Odoo在其中搜索模塊的目錄列表。

切換回您的sudo用戶:

exit

創建具有以下內容的配置文件,運行:

sudo nano /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

不要忘記將my_admin_passwd更改為更安全的方式。

 

四、創建系統單位文件及測試安裝

1、創建系統單位文件

打開您的文本編輯器,并創建一個名為odoo13.service的服務單元文件:

sudo nano /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

通知systemd一個新的單位文件存在:

sudo systemctl daemon-reload

啟動Odoo服務,并通過運行以下命令使其在啟動時啟動:

sudo systemctl enable --now odoo13

驗證服務狀態:

sudo systemctl status odoo13

輸出應如下所示,表明Odoo服務處于活動狀態并正在運行:

odoo13.jpg


要查看Odoo服務記錄的消息,請使用以下命令:

sudo journalctl -u odoo13

2、測試安裝

打開瀏覽器并輸入:http://<your_domain_or_IP_address>:8069。

假設安裝成功,將出現類似以下的屏幕:

2.JPG


 

五、將Nginx配置為SSL終止代理

默認的Odoo Web服務器通過HTTP提供流量,為了使Odoo部署更加安全,我們將Nginx配置為SSL終止代理,該代理將通過HTTPS提供流量。

SSL終止代理是處理SSL加密/解密的代理服務器,這意味著終止代理(Nginx)將處理并解密傳入的TLS連接(HTTPS),并將未加密的請求傳遞給內部服務(Odoo),Nginx和Odoo之間的流量不會被加密(HTTP)。

使用反向代理可以為您帶來很多好處,例如負載平衡、SSL終止、緩存、壓縮、提供靜態內容等。

在繼續本節之前,請確保您滿足以下先決條件:

1]、指向您的公共服務器IP的域名,我們將使用35e.net。

2]、已安裝Nginx,

3]、您的域的SSL證書,您可以安裝免費的Let's Encrypt SSL證書。

打開文本編輯器,然后創建/編輯域服務器塊:

sudo nano /etc/nginx/sites-enabled/35e.net

以下配置設置SSL終止,HTTP到HTTPS重定向,WWW到非WWW重定向,緩存靜態文件并啟用GZip壓縮:

# 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.weldinghelmetguides.com 35e.net;

include snippets/letsencrypt.conf;

return 301 https://35e.net$request_uri;

}

# WWW -> NON WWW

server {

listen 443 ssl http2;

server_name www.weldinghelmetguides.com;

ssl_certificate /etc/letsencrypt/live/35e.net/fullchain.pem;

ssl_certificate_key /etc/letsencrypt/live/35e.net/privkey.pem;

ssl_trusted_certificate /etc/letsencrypt/live/35e.net/chain.pem;

include snippets/ssl.conf;

return 301 https://example.com$request_uri;

}

server {

listen 443 ssl http2;

server_name 35e.net;

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;

# 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;

}

不要忘記用您的Odoo域替換example.com并為SSL證書文件設置正確的路徑,本文中創建了此配置中使用的摘錄。

完成后,重新啟動Nginx服務:

sudo systemctl restart nginx

接下來,我們需要告訴Odoo使用代理,為此,請打開配置文件并添加以下行,在/etc/odoo13.conf中:

proxy_mode = True

重新啟動Odoo服務以使更改生效:

sudo systemctl restart odoo13

至此,反向代理已配置完畢,您可以通過以下網址訪問您的Odoo實例:https://35e.net。

 

六、更改綁定界面(可選步驟)

此步驟是可選的,但這是一個很好的安全實踐。

默認情況下,Odoo服務器在所有接口上監聽8069端口,要禁用對Odoo實例的直接訪問,您可以阻止所有公共接口的8069端口,或強制Odoo僅在本地接口上偵聽。

我們將Odoo配置為僅監聽127.0.0.1,打開配置,在文件末尾添加以下兩行,在/etc/odoo13.conf中:

xmlrpc_interface = 127.0.0.1

netrpc_interface = 127.0.0.1

保存配置文件并重新啟動Odoo服務器,以使更改生效:

sudo systemctl restart odoo13

 

七、啟用多重處理

默認情況下,Odoo在多線程模式下工作,對于生產部署,建議更改為多處理服務器,因為它可以提高穩定性并更好地利用系統資源。

要啟用多處理,您需要編輯Odoo配置并設置非零數量的工作進程,根據系統中CPU內核的數量和可用的RAM內存來計算工作程序的數量。

根據Odoo的官方文檔來計算工人的數量和所需的RAM內存大小,您可以使用以下公式和假設:

1、工號計算

1]、理論上的最大工作者數= (system_cpus * 2) + 1。

2]、1個工作人員可以服務~= 6個并發用戶。

3]、Cron工人也需要CPU。

2、RAM內存大小計算

1]、我們將認為所有請求中有20%是重度請求,而80%是輕度請求,繁重的請求使用大約1 GB的RAM,而較輕的請求使用大約150 MB的RAM

2]、所需的RAM = number_of_workers * ( (light_worker_ratio * light_worker_ram_estimation) + (heavy_worker_ratio * heavy_worker_ram_estimation) )。

如果您不知道系統上有多少個CPU,請使用以下grep命令:

grep -c ^processor /proc/cpuinfo

假設您的系統具有4個CPU內核,8 GB RAM內存和30個并發Odoo用戶。

1]、30 users / 6 = **5**(5是所需的理論工人數)。

2]、(4 * 2) + 1 = **9**(9是理論上的最大工人人數)。

根據上面的計算,您可以使用5名工人+1名工人作為cron工人,總共6名工人。

根據工作線程數計算RAM內存消耗:

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

計算表明,Odoo安裝將需要大約2GB的RAM。

要切換到多處理模式,請打開配置文件并附加計算值,在/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

重新啟動Odoo服務以使更改生效:

sudo systemctl restart odoo13

其余的系統資源將由在此系統上運行的其他服務使用,在本文中,我們將Odoo與PostgreSQL和Nginx一起安裝在同一服務器上,根據您的設置,您可能還會在服務器上運行其他服務。

至此,在Ubuntu 18.04服務器上安裝Odoo 13的全部步驟操作完成了,您可以隨時應用搭載好的Odoo 13環境。



資訊內容

誠信為本,卓越品質,做行業領跑者