提升 Odoo 开发效率:Ubuntu 22.04 + Makefile 的最佳实践

作为一名 Odoo 开发人员,我强烈建议使用 Ubuntu 22.04 作为开发环境。这一版本的 Ubuntu 具有较高的稳定性和兼容性,非常适合进行 Odoo 的开发工作。为了提高日常开发效率,我通常会利用 Makefile 来管理一些常用的命令和操作流程。 以下是我的 Makefile 内容,它涵盖了从运行服务器到清理日志、终止进程等常用功能:

  • 运行 Odoo 服务,并启用所有开发者模式选项,同时将工具转换的日志级别设置为 DEBUG。
makefile 复制代码
run: kill clean
    venv/bin/python odoo-bin --config=./odoo.conf --dev=all --log-handler odoo.tools.convert:DEBUG
  • 启动 Odoo 交互式 Shell,方便调试数据库中的数据或执行 Python 代码。
makefile 复制代码
shell:
    venv/bin/python odoo-bin shell --config=./odoo.conf -d $(database)
  • 将本地代码提交至远程仓库。
makefile 复制代码
push:
    git push
  • 从远程仓库拉取最新的代码更新。
makefile 复制代码
pull: git pull
  • 清空 Odoo 服务器的日志文件,确保不会受到旧日志干扰。
makefile 复制代码
clean:
    echo "" > odoo-server.log
  • 检查并终止占用端口 8069 的进程。如果找到相关进程,则强制终止;否则提示未发现任何进程。
makefile 复制代码
kill:
    $(eval PID := $(shell netstat -tunlp 2>/dev/null | grep ':8069 ' | awk '{print $$7}' | cut -d'/' -f1))
	@if [ -n "$(PID)" ]; then echo "Killing process $(PID)"; kill -9 $(PID); else echo 'No process found'; fi
  • 检查指定模块是否能够正常加载,并在初始化完成后停止服务。
makefile 复制代码
check:
    clean venv/bin/python odoo-bin -c odoo.conf -d $(database) -u $(module) --stop-after-init
  • 导出指定模块的语言翻译文件,便于后续进行多语言支持的开发。
makefile 复制代码
translate:
    venv/bin/python odoo-bin --config=./odoo.conf -d test-db --language=en_US --modules=product --i18n-export=product.pot

通过上述 Makefile,我们可以非常方便地管理 Odoo 项目的各种操作。例如,make run可以快速启动 Odoo 服务,而make kill则能轻松终止可能存在的冲突进程。此外,make check可以帮助我们验证模块的正确性,而make translate则提供了生成翻译文件的功能。这些命令极大地简化了开发过程,使开发者能够更专注于核心业务逻辑的实现。

相关推荐
superman超哥3 分钟前
仓颉语言中并发集合的实现深度剖析与高性能实践
开发语言·后端·python·c#·仓颉
superman超哥4 分钟前
仓颉语言中原子操作的封装深度剖析与无锁编程实践
c语言·开发语言·后端·python·仓颉
⑩-4 分钟前
SpringCloud-Feign客户端实战
后端·spring·spring cloud
阿杰AJie5 分钟前
Docker 容器启动的全方位方法汇总
后端
sdguy20 分钟前
在 Windows 上正确安装 OpenAI Codex CLI:一次完整的 pnpm 全局环境修复实录
后端·openai
shiwulou138 分钟前
PbRL | 近两年论文阅读的不完全总结
后端
yuniko-n1 小时前
【MySQL】通俗易懂的 MVCC 与事务
数据库·后端·sql·mysql
今天过得怎么样1 小时前
彻底搞懂 Spring Boot 中 properties 和 YAML 的区别
后端
qq_12498707531 小时前
基于springboot的幼儿园家校联动小程序的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·spring·微信小程序·小程序
武子康2 小时前
大数据-189 Nginx JSON 日志接入 ELK:ZK+Kafka+Elasticsearch 7.3.0+Kibana 实战搭建
大数据·后端·elasticsearch