《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案
一、项目背景
化工行业生产过程复杂,设备运行条件恶劣,对设备状态监测、生产数据采集和质量控制的要求极高。通过开源Odoo MES系统与SKF Observer Phoenix API的双向对接,可以实现设备状态的实时监测、生产数据的自动化采集以及质量数据的同步,从而提升化工企业的生产效率和管理水平。
二、集成目标
-
设备状态监测:通过SKF Observer Phoenix API获取设备的振动、温度、压力等状态数据,实时同步到Odoo MES系统。
-
生产数据采集:利用Odoo MES系统采集生产现场的设备运行数据和生产进度数据,实现生产过程的可视化。
-
质量数据同步:同步生产过程中的质量检测数据,确保产品质量符合标准。
三、技术架构
- Odoo MES模块:
• 设备管理:用于设备状态监测和维护工单管理。
• 生产管理:用于生产数据采集和生产进度跟踪。
• 质量管理:用于质量检测数据的记录和分析。
- SKF Observer Phoenix API:
• 提供设备状态监测数据(如振动、温度等)。
• 支持通过API接收维护工单状态更新。
- 中间层:
• 使用Python脚本作为调度器,定时拉取SKF数据并触发Odoo业务逻辑。
四、集成方案
(一)设备状态监测集成
- 数据模型设计
# models/maintenance_equipment.pyfrom odoo import models, fieldsclass MaintenanceEquipment(models.Model):_inherit = 'maintenance.equipment'skf_id = fields.Char('SKF设备ID')vibration_threshold = fields.Float('振动阈值(mm/s)')temperature_threshold = fields.Float('温度阈值(℃)')last_sync_time = fields.Datetime('最后同步时间')
- 定时任务实现
# models/maintenance_sync.pyfrom odoo import models, apiimport requestsimport loggingclass MaintenanceSync(models.Model):_name = 'maintenance.sync'@api.modeldef cron_sync_equipment_status(self):equipments = self.env['maintenance.equipment'].search([('skf_id', '!=', False)])skf_api_key = self.env['ir.config_parameter'].sudo().get_param('skf.api_key')for equipment in equipments:url = f"https://api.skf.com/observer/v1/devices/{equipment.skf_id}/sensor_data"params = {'start_time': equipment.last_sync_time.isoformat() if equipment.last_sync_time else '2024-01-01T00:00:00Z'}headers = {'Authorization': f'Bearer {skf_api_key}'}try:response = requests.get(url, headers=headers, params=params)data = response.json()for entry in data.get('data', []):if entry['vibration'] > equipment.vibration_threshold or entry['temperature'] > equipment.temperature_threshold:self.env['maintenance.request'].create({'name': f"设备{equipment.name}状态异常",'equipment_id': equipment.id,'description': f"振动值:{entry['vibration']} mm/s,温度:{entry['temperature']} ℃"})equipment.last_sync_time = fields.Datetime.now()except Exception as e:logging.error(f"同步失败: {str(e)}")
- 真实案例:某化工企业通过部署设备状态监测系统,成功减少了设备突发停机事件,提高了设备的运行效率。
(二)生产数据采集集成
- 数据模型设计
# models/production_data.pyfrom odoo import models, fieldsclass ProductionData(models.Model):_name = 'production.data'equipment_id = fields.Many2one('maintenance.equipment', '设备')timestamp = fields.Datetime('时间戳')production_rate = fields.Float('生产速率')quality_index = fields.Float('质量指数')
- 数据采集实现
# models/production_sync.pyfrom odoo import models, apiimport requestsimport loggingclass ProductionSync(models.Model):_name = 'production.sync'@api.modeldef cron_sync_production_data(self):equipments = self.env['maintenance.equipment'].search([('skf_id', '!=', False)])skf_api_key = self.env['ir.config_parameter'].sudo().get_param('skf.api_key')for equipment in equipments:url = f"https://api.skf.com/observer/v1/production_data/{equipment.skf_id}"headers = {'Authorization': f'Bearer {skf_api_key}'}try:response = requests.get(url, headers=headers)data = response.json()for entry in data.get('production_data', []):self.env['production.data'].create({'equipment_id': equipment.id,'timestamp': entry['timestamp'],'production_rate': entry['production_rate'],'quality_index': entry['quality_index']})except Exception as e:logging.error(f"数据采集失败: {str(e)}")
- 真实案例:某化工企业通过部署生产数据采集系统,实现了生产过程的实时监控和数据分析,提高了生产效率。
(三)质量数据同步集成
- 数据模型设计
# models/quality_check.pyfrom odoo import models, fieldsclass QualityCheck(models.Model):_name = 'quality.check'product_id = fields.Many2one('product.product', '产品')check_date = fields.Datetime('检测日期')result = fields.Selection([('pass', '合格'), ('fail', '不合格')], '检测结果')notes = fields.Text('备注')
- 数据同步实现
# controllers/quality_sync.pyfrom odoo import httpimport requestsimport jsonclass QualitySyncController(http.Controller):@http.route('/quality/sync', type='json', auth='user')def sync_quality_data(self):skf_api_key = http.request.env['ir.config_parameter'].sudo().get_param('skf.api_key')url = "https://api.skf.com/observer/v1/quality_data"headers = {'Authorization': f'Bearer {skf_api_key}'}try:response = requests.get(url, headers=headers)data = response.json()for entry in data.get('quality_checks', []):product = http.request.env['product.product'].search([('default_code', '=', entry['product_code'])])if product:http.request.env['quality.check'].create({'product_id': product.id,'check_date': entry['check_date'],'result': entry['result'],'notes': entry['notes']})return {'success': True}except Exception as e:return {'error': str(e)}
- 真实案例:某化工企业通过部署质量数据同步系统,实现了生产过程中的质量检测数据实时同步,确保产品质量符合标准。
五、安全与配置
-
API密钥管理:在Odoo的系统参数中存储SKF API密钥,通过加密字段保护。
-
HTTPS加密:所有API调用均通过HTTPS传输,确保数据安全。
-
IP白名单:限制SKF API仅允许Odoo服务器的IP访问。
六、部署与测试
- 部署步骤:
• 安装Odoo自定义模块。
• 配置定时任务,如每30分钟同步一次设备状态数据。
• 在SKF Observer API中注册Odoo的Webhook URL。
- 测试案例:
• 设备状态同步测试:模拟设备振动异常,验证是否自动生成维护工单。
• 生产数据采集测试:实时采集生产数据,验证数据的完整性和准确性。
• 质量数据同步测试:同步质量检测数据,验证是否正确记录在Odoo中。
七、总结与展望
通过Odoo MES系统与SKF Observer Phoenix API的双向集成,化工企业实现了设备状态的实时监测、生产数据的实时采集以及质量数据的同步,提升了生产效率和智能化管理水平。未来可以进一步扩展功能,如集成数字孪生技术,实现生产过程的可视化监控。
让转型不迷航——邹工转型手札
相关文章:
《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案
一、项目背景 化工行业生产过程复杂,设备运行条件恶劣,对设备状态监测、生产数据采集和质量控制的要求极高。通过开源Odoo MES系统与SKF Observer Phoenix API的双向对接,可以实现设备状态的实时监测、生产数据的自动化采集以及质量数据的同步…...
oracle11g搭建主从集群
安装oracle11g参考:centos安装oracle11g数据库-CSDN博客 一、主库操作 sqlplus / as sysdba 1、开启归档模式和强制日志模式 shutdown immediate startup mount #开启归档模式和强制日志模式 alter database archivelog; alter database force logging; #开启补…...
暂未整理啊
测码学院 python的数据类型 不可变数据类型:字符串/数字/元组/ type(变量名) 获得数据的类型 str:字符串 int:整数 float:浮点数 bool:true/false 布尔类型 list:列表 dict&…...
重庆西站公路桥梁自动化监测
1.项目概述 重庆西站属于渝黔铁路的配套工程,是承担兰渝、川黔、渝昆等多条铁路的特级客运站,未来重庆铁路三大客运站之一。作为我国西部地区规模最大的火车站、重庆西站于2014年在沙坪坝区上桥开工建设,该站东临内环高速,西靠中梁山&#x…...
JavaScript系列(70)--响应式编程进阶详解
JavaScript响应式编程进阶详解 🔄 今天,让我们深入探讨JavaScript响应式编程的进阶内容。响应式编程是一种强大的编程范式,它能够帮助我们更好地处理异步数据流和状态管理。 响应式编程进阶概念 🌟 💡 小知识&#x…...
安装指定版本的pnpm
要安装指定版本的 pnpm,可以使用以下方法: 方法 1: 使用 pnpm 安装指定版本 你可以通过 pnpm 的 add 命令来安装指定版本: pnpm add -g pnpm<版本号>例如,安装 pnpm 的 7.0.0 版本: pnpm add -g pnpm7.0.0方法…...
Dockerfiles 的 Top 10 常见 DevOps/SRE 面试问题及答案
1. RUN 和 CMD 之间有什么区别? RUN : 在镜像构建过程中执行命令,创建一个新的层。通常用于安装软件包。 示例: RUN apt-get update && apt-get install -y curlCMD : 指定容器启动时默认运行的命令。它在运行时执行,而不是在构建过程…...
头条百度批量采集软件说明文档
旧版说明文档《头条号文章批量采集软件4.0版本说明文档!头条/微头条文章批量采集》 头条的采集软件已经更新了好多个版本了,一直没有做详细的介绍文档,最近更新了一些功能进去,一块来写一下说明文档。 1、主界面 2、头条作者采集…...
36.日常算法
1.最小栈 题目来源 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。 void push(int val) 将元素val推入堆栈。 void pop() 删除堆栈顶部的元素。 int top() 获取堆…...
计算机考研复试上机04
目录 6、向量 1)完数与盈数(清华大学复试上机题) 7、队列 1)约瑟夫问题 No. 2 8、栈 1)简单计算器(浙江大学复试上机题) 2)堆栈的使用(吉林大学复试上机题…...
【面试】面试常见的智力题
引言 在技术面试中,除了考察编程能力和算法知识外,智力题也是常见的考察方式。智力题不仅能够测试候选人的逻辑思维能力,还能反映其解决问题的创造力和应变能力。本文将整理一些常见的面试智力题,并详细分析解题思路,…...
【动态规划】风扫枯杨,满地堆黄叶 - 9. 完全背包问题
本篇博客给大家带来的是完全背包问题之动态规划解法技巧. 🐎文章专栏: 动态规划 🚀若有问题 评论区见 ❤ 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 . 王子,公主请阅🚀 要开心要快乐顺…...
BGP基础协议详解
BGP基础协议详解 一、BGP在企业中的应用二、BGP概述2.1 BGP的特点2.2 基本配置演示2.3 抓包观察2.4 BGP的特征三、BGP对等体关系四、bgp报文4.1 BGP五种报文类型(重点)4.2 BGP报文格式-报文头格式4.3 Open报文格式4.4 Update报文格式4.5 Notification报文格式4.6 Route-refre…...
LeetCode刷题---数组---840
矩阵中的幻方 https://leetcode.cn/problems/magic-squares-in-grid/submissions/598584907/ 题目: 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵,其中每行,每列以及两条对角线上的各数之和都相等。 给定一个由整数组成…...
Visual Studio踩过的坑
统计Unity项目代码行数 编辑-查找和替换-在文件中查找 查找内容输入 b*[^:b#/].*$ 勾选“使用正则表达式” 文件类型留空 也有网友做了指定,供参考 !*\bin\*;!*\obj\*;!*\.*\*!*.meta;!*.prefab;!*.unity 打开Unity的项目 注意:只是看࿰…...
【深度学习入门实战】基于Keras的手写数字识别实战(附完整可视化分析)
本人主页:机器学习司猫白 ok,话不多说,我们进入正题吧 项目概述 本案例使用经典的MNIST手写数字数据集,通过Keras构建全连接神经网络,实现0-9数字的分类识别。文章将包含: 关键概念图解完整实现代码训练过程可视化模型效果深度分析环境准备 import numpy as np impo…...
SkyWalking 10.1.0 实战:从零构建全链路监控,解锁微服务性能优化新境界
文章目录 前言一、集成SkyWalking二、SkyWalking使用三、SkyWalking性能剖析四、SkyWalking 告警推送4.1 配置告警规则4.2 配置告警通知地址4.3 下发告警信息4.4 测试告警4.5 慢SQL查询 总结 前言 在传统监控系统中,我们通过进程监控和日志分析来发现系统问题&…...
计算机毕业设计——Springboot的旅游管理
🎉**欢迎来到琛哥的技术世界!**🎉 📘 博主小档案: 琛哥,一名来自世界500强的资深程序猿,毕业于国内知名985高校。 🔧 技术专长: 琛哥在深度学习任务中展现出卓越的能力&a…...
【通俗易懂说模型】反向传播(附多元分类与Softmax函数)
🌈 个人主页:十二月的猫-CSDN博客 🔥 系列专栏: 🏀深度学习_十二月的猫的博客-CSDN博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 目录 1. 前言 2. …...
Kickstart自动化安装过程中自动选择较小的磁盘安装操作系统
Kickstart自动化安装过程中自动选择较小的磁盘安装操作系统 需求 在实际生成操作过程中,一般会遇到物理服务器存在多块盘的情况。 安装过程中,磁盘的标签是随机分配的,并不是空间较小的盘,就会使用较小的磁盘标签 而需求往往需要…...
128,【1】buuctf [极客大挑战 2019]PHP
进入靶场 提示了备份文件 抓包,扫描 扫描出了两个有反应的 访问index.php没反应,但www.zip成功下载了文件 index.php里得到如下有用信息 <?phpinclude class.php;$select $_GET[select];$resunserialize($select);?> 所以我们要通过GET 方…...
3.3 学习UVM中的uvm_driver 类分为几步?
文章目录 前言1. 定义2. 核心功能3. 适用场景4. 使用方法5. 完整代码示例5.1 事务类定义5.2 Driver 类定义5.3 Sequencer 类定义5.4 测试平台 6. 代码说明7. 总结 前言 以下是关于 UVM 中 uvm_driver 的详细解释、核心功能、适用场景、使用方法以及一个完整的代码示例ÿ…...
系统思考—双环学习
前几天,一个企业高管向我提到:“我们调整了N次方案,市场策略、团队激励、管理制度,能改的全改了,怎么还是不见起色?” 这让我想到典型的单环学习,简单来说就是:发现问题 → 采取行动…...
QTreeView和QTableView单元格添加超链接
QTreeView和QTableView单元格添加超链接的方法类似,本文仅以QTreeView为例。 在QTableView仿Excel表头排序和筛选中已经实现了超链接的添加,但是需要借助delegate,这里介绍一种更简单的方式,无需借助delegate。 一.效果 二.实现 QHTreeView.h #ifndef QHTREEVIEW_H #def…...
elastic search 的 highlight
Elasticsearch 的 highlight 功能用于在搜索结果中突出显示匹配的文本片段。这对于用户界面上的搜索结果展示非常有用,因为它可以帮助用户快速定位到他们搜索的关键词。 1. 基本用法 在 Elasticsearch 中,highlight 功能通常在查询中使用,并…...
【MySQL篇】行格式详解
MySQL行格式详解 文章目录 MySQL行格式详解🎉 什么是行格式🐱👤 如何查看行格式🐱🚀 InnoDB 行格式有哪些?🐱🏍 Compact 行格式🚩 额外信息🚀 变长字段…...
嵌入式知识点总结 操作系统 专题提升(五)-内存
针对于嵌入式软件杂乱的知识点总结起来,提供给读者学习复习对下述内容的强化。 目录 1.在1G内存的计算机能否malloc(1.2G)?为什么? 2.malloc能申请多大的空间? 3.内存管理有哪几种方式? 4.什…...
动手学深度学习---深层神经网络
目录 一、神经网络1.1、模型训练1.2、损失函数1.2.1、分类:hinge loss/合页损失/支持向量机损失1.2.2、分类:交叉熵损失(softmax分类器)1.2.2.1 二分类交叉熵损失1.2.2.2 多分类交叉熵损失 1.2.3、回归:误差平方和(SSE)…...
第9章 城市基础设施更新工程 9.1 道路改造施工
9.1 道路改造施工 9.1.1 道路改造施工内容 沥青、水泥混凝土、砌块路面及人行步道、绿化照明、附属设施、交通标志。沥青路面材料的再生利用。 9.1.2 道路改造施工技术 1.沥青路面病害及微表处理 1.病害处理 裂缝处理 10mm以内 专用灌缝材料、热沥青灌缝、缝内潮湿时采用…...
java基础6(黑马)
一、static 1.static修饰成员变量 static:叫静态,可以修饰成员变量、成员方法。 成员变量按照有无static,分两种。 类变量:有static修饰,属于类,在计算机中只有一份,会被类的全部对象共享。…...
