odoo18应用、队列服务器分离(SSHFS)

目录

[1. 背景](#1. 背景)

2.环境准备

[3. conf配置](#3. conf配置)

3.1应用服务器

[3.2 队列服务器](#3.2 队列服务器)

4.结果演示


1. 背景

在大型企业或高并发业务场景下,Odoo 的应用层和后台任务处理层往往会产生资源竞争。随着业务规模的增长,用户在操作界面(应用服务器)与后台异步任务(队列服务器)之间的耦合问题会逐渐凸显。将 Odoo 应用服务器 与 Queue Job 队列服务器 进行架构分离,是一种更高效、可扩展、符合现代分布式设计的方案。本文介绍基于 SSHFS 模式的 队列服务器和应用服务器分离。

2.环境准备

准备两个服务器

服务器1 4核4G 10.1.8.15 odoo 的data_dir 路径 /opt/odoo18_data

服务器2 2核2G 10.1.20.2

这两个服务器的 内网IP位于同一个局域网下面

应用服务器:安装 openssh-server

bash 复制代码
sudo apt update && sudo apt install openssh-server

队列服务器:

安装sshfs

sudo apt install sshfs

实际挂载点创建

sudo mkdir -p /opt/odoo18_data

sudo sshfs -o allow_other,default_permissions ubuntu@10.1.8.15:/opt/odoo18_data /opt/odoo18_data

ubuntu 是服务器1 的登录名

挂载之后可以去看一下应用服务器的这个文件夹是否过来了

3. conf配置

3.1应用服务器

bash 复制代码
[options]
addons_path = /home/ubuntu/odoo18/odoo/addons,/home/ubuntu/odoo18/myaddons
db_host = localhost
proxy_mode = True
gevent_port = 8072
db_port = 5432
db_name = False
bin_path = /usr/local/bin
http_port = 8068
db_user = odoo
db_password = odoo
logfile = ./odoo18.log
limit_request = 8192
limit_time_cpu = 600
limit_time_real = 60000
limit_time_real_cron = -1
list_db = True
server_wide_modules = base,web
data_dir = /opt/odoo18_data
workers = 4                 
max_cron_threads = 2        
limit_memory_hard = 2684354560  
limit_memory_soft = 2147483648

这里的应用服务器用的是 NGINX 代理本地的 localhost:8068

server_wide_modules 去除 queue_job 即应用服务器不跑队列

3.2 队列服务器

bash 复制代码
db_port = 5432
db_name = False

db_user = odoo
db_password = odoo
#logfile = ./odoo18.log
limit_request = 8192
limit_time_cpu = 600
limit_time_real = 60000
limit_time_real_cron = -1
list_db = True
server_wide_modules = base,web,queue_job
data_dir = /opt/odoo18_data
              
max_cron_threads = 0
limit_memory_hard = 2684354560
limit_memory_soft = 2147483648
http_enable = False

[queue_job]
channels = root:4
port = 8068
host = 10.1.8.15

注意: http_port 需要设置为False,因为我们的队列服务器已经不需要开启HTTP服务了,http_port 参数也不需要设置

关于 queue_job 的配置说明

channels = root:4 设置默认队列为 root队列,开启四个 work

port = 8068

host = 10.1.8.15

队列完成任务的时候向应用服务器 发起回调;host、port 也就是应用服务器的地址和http端口

4.结果演示

当我们只开启应用服务器,生成队列任务的时候, 任务都是等待状态

这时开启队列服务器的进程:

可以看到 通过应用服务器生成的任务这时已经开始执行,通过应用服务器1 的queue_job的web页面可以看到任务已经是完成状态。 到此 基于 SSHFS 模式的 应用服务器和队列服务器基本配置完成,但是相对于NFS,SSHFS的性能还是不大行,当并发量大起来的时候还是得考虑 NFS 进行文件共享,后续有空再出一个NFS的教程...

相关推荐
ZHANG13HAO21 小时前
OK3568 Android11 实现 App 独占隔离 CPU 核心完整指
linux·运维·服务器
梁正雄1 天前
16、Docker swarm-3
运维·docker·容器
quan_泉1 天前
2025信阳市中等职业教育竞赛_网络安全赛项部分题解
linux·服务器·php
null or notnull1 天前
java服务器空间不够时:将多个服务器的文件存放至同一个服务器上(使用映射器的办法)
java·运维·服务器·java-ee
傲世(C/C++,Linux)1 天前
Linux系统编程——exec函数族
linux·服务器
盈创力和20071 天前
物联网 “神经” 之以太网:温湿度传感器的工业级 “高速干道”
运维·服务器·网络·嵌入式硬件·以太网温湿度传感器
eddy-原1 天前
阿里云核心服务解析与应用实践
linux·运维·阿里云·云计算
路由侠内网穿透.1 天前
外网访问可视化工具 Grafana (Linux版本)
linux·运维·服务器·grafana·远程工作
爱吃糖的小秦同学1 天前
Docker爆红且安装非C盘处理方案
运维·docker·容器
睿本云1 天前
产品月报|睿本云10月产品功能迭代
运维·服务器·apache