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的教程...

相关推荐
范桂飓3 小时前
在 Windows GPU 机器上运行 Linux CUDA
linux·运维·windows
虚伪的空想家3 小时前
生产环境K8S的etcd备份脚本
运维·容器·kubernetes·脚本·备份·etcd
蓝婴天使3 小时前
Debian13 钉钉无法打开问题解决
linux·服务器·钉钉
孙克旭_4 小时前
kind部署K8S集群并将“修仙业务“部署到kind集群
linux·运维·云原生·kubernetes·kind
IT成长日记4 小时前
【LVS入门宝典】探秘LVS透明性:客户端如何“看不见”后端服务器的魔法
运维·服务器·负载均衡·lvs·透明性
IT成长日记4 小时前
【LVS入门宝典】LVS DR模式深度解析:直接路由(DR)的高性能秘诀,MAC地址欺骗与ARP隔离
linux·运维·负载均衡·lvs·arp
小红帽6155 小时前
Web服务器(Nginx和Apache)
服务器·前端·nginx
wanhengidc5 小时前
新手玩家如何使用云手机
运维·服务器·网络·游戏·智能手机
半梦半醒*5 小时前
在Linux中部署tomcat
java·linux·运维·服务器·centos·tomcat