Odoo 是最流行的 ERP(企业资源计划)软件,它由 Python 编写,使用 PostgreSQL 作为后端数据库。Odoo 社区版是免费的开源软件,它囊括了项目管理,生产、财务、记账和销售管理,仓储管理,人力资源管理,甚至还有更多项目。里面包含了 30 个核心模块,以及超过 3000 个社区模块。Odoo 部署了大量的模块,数据库里也包含了庞大的数据等等,这些都使得这个软件比较复杂,可能会导致效率低下。Odoo 的两个主要瓶颈在于磁盘访问,以及数据库查询时间。

为了提升 Odoo 实例的性能,你可以:

  • 使用一个快速磁盘驱动器来存储(最好是 SSD)。
  • 使用内存充足的 Linux VPS。
  • 在 Odoo 中激活多处理器模式multiprocessing mode。
  • 正确配置并优化 PostgreSQL 服务。

获得一台有着更多内存的 SSD VPS

正如我们先前提到的,随机磁盘访问速度是 Odoo 的主要瓶颈之一。因此,要确保 Odoo 部署在一台基于 SSD 的 VPS 上。由于 Odoo 是一个对资源十分敏感的应用,因此始终要把它安装在一台有着更多 RAM 的 VPS 上,如果可能,将整个 Odoo 实例及其数据库加载到 RAM 中。固态磁盘驱动器尤其以随机存取见长,而且由于 SSD 没有任何活动部件,它们能够取得数百倍于传统机械硬盘驱动器的随机存取 IOPS(LCTT译注:即每秒读写操作的次数)。如果服务器没有采用 SSD 来驱动或提速,那么不管你对 Odoo 做多少优化和配置都无济于事,它仍然会很慢。所以,获得正确的主机来部署 Odoo 是提升其性能的最重要因素。

其它 Odoo 优化包括:

在 Odoo 配置中启用多处理器选项

要实现此功能,请定位到 openerp-server 二进制文件:

  1. #updatedb
  2. #locate openerp-server
  3. /usr/bin/openerp-server

执行以下命令:

  1. #/usr/bin/openerp-server --help

该命令的输出结果如下:

  1. Usage: openerp-server [options]
  2. Options:
  3. --version show program's version number and exit
  4. (...)
  5. Multiprocessing options:
  6. --workers=WORKERS Specify the number of workers, 0 disable prefork mode.
  7. --limit-memory-soft=LIMIT_MEMORY_SOFT
  8. Maximum allowed virtual memory per worker, when
  9. reached the worker be reset after the current request
  10. (default 671088640 aka 640MB).
  11. --limit-memory-hard=LIMIT_MEMORY_HARD
  12. Maximum allowed virtual memory per worker, when
  13. reached, any memory allocation will fail (default
  14. 805306368 aka 768MB).
  15. --limit-time-cpu=LIMIT_TIME_CPU
  16. Maximum allowed CPU time per request (default 60).
  17. --limit-time-real=LIMIT_TIME_REAL
  18. Maximum allowed Real time per request (default 120).
  19. --limit-request=LIMIT_REQUEST
  20. Maximum number of request to be processed per worker
  21. (default 8192).

工作进程的数量应该和分配到 VPS 的 CPU 核心数一样,或者,如果你想为 PostgreSQL 数据库、cron 任务、或者其它和 Odoo 实例安装在同一台 VPS 上的其它应用预留出一些 CPU 核心,那么你可以将工作进程数设置为一个比 VPS 上可用 CPU 核心更低的值,以避免资源耗尽。

limit-memory-soft 和 limit-memory-hard 参数不言自明,你可以使用默认值,也可以根据 VPS 上的实际可用 RAM 来进行修改。

例如,如果你的 VPS 有 8 个 CPU 核心,以及 16 GB 内存,那么你可以将工作进程数设置为 17(CPU 核心数 x 2 + 1),limit-memory-soft 总值设置为 640 x 17 = 10880 MB,而 limit-memory-hard 总数设置为 68MB x 17 = 13056 MB,这样,Odoo 就会有总计达 12.75 GB 的 RAM。

例如,在一台拥有 16 GB RAM 和 8 个 CPU 核心的 VPS 上,编辑 Odoo 配置文件(如 /etc/odoo-server.conf),并添加以下行:

  1. vi /etc/odoo-server.conf
  1. workers = 17
  2. limit_memory_hard = 805306368
  3. limit_memory_soft = 671088640
  4. limit_request = 8192
  5. limit_time_cpu = 60
  6. limit_time_real = 120
  7. max_cron_threads = 2

别忘了重启 Odoo 让修改生效。

正确配置并优化 PostgreSQL

对于 PostgreSQL 优化,及时将它更新到最新版本是一个不错的主意。在 PostgreSQL 配置文件(pg_hba.conf)中,有两个设置需要修改:shared_buffers 和 effective_cache_size。将shared_buffers 设置为可用内存的 20%,effective_cache_size 设置为可用内存的 50%。

例如,如果 Odoo 安装到了一台 16 GB RAM 的 SSD VPS 上,那么在 pg_hba.conf 中使用如下设置:

  1. vi /var/lib/postgresql/data/pg_hba.conf
  1. shared_buffers = 3072MB
  2. effective_cache_size = 8192MB

重启 PostgreSQL 服务来让修改生效。

同时,也别忘了周期性手动执行 ‘VACUUM’。此操作会将陈旧或临时数据清理干净,但请牢记,它会大量占用 CPU 和磁盘使用。

原文发布时间为:2017-03-14

本文来自云栖社区合作伙伴“Linux中国”

开源 ERP 软件 Odoo 提速指南相关推荐

  1. 开源ERP软件Odoo提速指南

    Odoo 是最流行的 ERP(企业资源计划)软件,它由 Python 编写,使用 PostgreSQL 作为后端数据库.Odoo 社区版是免费的开源软件,它囊括了项目管理,生产.财务.记账和销售管理, ...

  2. python开发erp系统odoo_开源erp软件odoo在线开发环境部署实录

    1.前言 pscloud(odoo)是优秀的开源erp,采用微应用方式向企业客户交付业务应用功能,包含海量的经过全球客户验证的业务应用APP,且odoo基于python的底层框架也非常优秀,特别适合于 ...

  3. 开源erp软件odoo在线开发环境部署实录

    1.前言 pscloud(odoo)是优秀的开源erp,采用微应用方式向企业客户交付业务应用功能,包含海量的经过全球客户验证的业务应用APP,且odoo基于python的底层框架也非常优秀,特别适合于 ...

  4. 【魅力开源】第7集:开源ERP系统Odoo发展史(Odoo中文社区野史2019版)

    文章目录 前言 历程 后记 前言 开源 ERP 系统 Odoo 的发展史. 历程 2002 年比利时13 岁开 始学习编程序的 Fabien Pinckaers 所创建创办了Tiny Sprl 公司. ...

  5. 开源ERP系统Odoo中国发展史

    开源ERP系统Odoo中国发展史 根据上海开阖-Jeff最初文稿整理 开源ERP系统Odoo采用Python作为其开发语言,从诞生之日已有15年历史,在中国也有10年历史了. 开源软件(GNU通用公共 ...

  6. 跟我学,轻松安装开源ERP软件Open ERP

    跟我学,轻松安装开源ERP软件Open ERP http://www.linuxeden.com/html/solution/20090701/66521.html Open ERP原名Tiny ER ...

  7. 排名最前的6款开源ERP软件比较

    为何选择OpenERP而不是其它的openbravo, Compiere, ADempiere, Apache OFBiz, ERP5, webERP, Tryton, BlueERP, ERPNex ...

  8. 盘点世界排名最前的5款开源ERP软件

    盘点世界排名最前的5款开源ERP软件 盘点世界排名最前的5款开源ERP软件 « 于: 十一月 03, 2012, 11:15:42 下午 » 引用 Add Multi Quote Remove Mul ...

  9. 世界排名第一的永久免费开源ERP:Odoo生产制造管理功能概述

    本文节选自Odoo亚太金牌服务机构[开源智造]所编写的<ERP真的免费不花钱--Odoo应用指南>如需获取完整的知识内容,请至开源智造官网免费获取.感谢网友一键三连:点赞.转发.收藏,您的 ...

最新文章

  1. 字节首推Java成长笔记:(原理+应用+源码+调优全都有)
  2. hbase 修改表名_HBase学习——2.HBase原理
  3. python输入输出重定向_Python标准输出重定向
  4. form提交后台注解拿不到数据_Form表单详解
  5. 老的消息中间件投递失败的类型值_RabbitMQ消息中间件技术精讲11 高级篇四 confirm 确认消息...
  6. HDU3183 A Magic Lamp —— 贪心(单调队列优化)/ RMQ / 线段树
  7. oracle中packages使用,oracle中packages的使用
  8. 链表 python 牛客_牛客网《剑指offer》之Python2.7实现:合并两个排序的链表
  9. 【Elasticsearch】elasticsearch bool 布尔 查询
  10. TensorFlow 1.11.0正式版发布了,强力支持Keras
  11. 自学python能找到工作吗-自学 Python,我是如何找到工作的?
  12. oracle授权v$lock,Oracle八大性能视图之v$lock
  13. mysql数据库用doc命令,myMySQL数据库怎么使用dos命令安装? MySQL数据库使用教程
  14. 视力测试软件正确吗,体检视力测试
  15. ArcGis 地理配准注意事项
  16. ValueError: Sample larger than population or is negative
  17. Gradle项目在IDEA中运行时提示:Unnecessarily replacing a task that does not exist is not supported. Use create
  18. 图像翻译/Transformer:ITTR: Unpaired Image-to-Image Translation with Transformers用Transfor进行非配对图像对图像的转换
  19. 无光照渲染shader-二次元
  20. 考研词汇 用语言记忆

热门文章

  1. 前台之boostrap
  2. LVS+Heartbeat+Ipvsadm+Ldirectord安装 (一)
  3. 微软称伊朗国家黑客攻击美国国防技术公司
  4. Linux 内核修复5个高危漏洞
  5. 安全界“圣经”DBIR 报告推翻了哪些“你以为的”数据泄漏情况?
  6. 我发现了25个影响力达20多年的 Windows 0day,微软刚修完11个
  7. matlab练习程序(图像序列合成视频)
  8. Kubernetes集群部署1
  9. 云计算网络基础第一天
  10. java----Servlet的生命周期