【N8N数据转换:MQTT-MYSQL】

N8N数据转换:MQTT-MYSQL

背景说明

复制代码
 n8n是一个控制颗粒度可以很细的智能工作流编排工具,本文章的使用场景:订阅MQTT数据,检查MQTT数据,写入MYSQL,整个过程可视化操作,效率比写代码更高;

流程图

ParseDataPackets数据解析

  • 对两种数据包做了判断,若有新的增加新的判断代码即可;
javascript 复制代码
var result={currProduction:0,Cid:""};
if ($input.first().json.message.hasOwnProperty('paraslist')==false){
  return result;
}
   if ($input.first().json.message.paraslist.hasOwnProperty('productionCount')==false){
     return result;      
}
var Cid=$input.first().json.message.collectorid;
result.Cid=Cid;
result.currProduction=Number($input.first().json.message.paraslist.productionCount);
return result;  

ProductionCale节点 产量计算

javascript 复制代码
var result={Count:0,Cid:$('ParseDataPackets').first().json.Cid};
var currProduction=$('ParseDataPackets').first().json.currProduction;
if ($input.first().json.Production==null){    
    result.Count=0;
}else{
  var lastProduction=Number($input.first().json.Production) || 0;
  if (currProduction==lastProduction){
    result.Count=0;    
  }else if (currProduction>lastProduction){
    result.Count=currProduction-lastProduction;    
  }else {
    result.Count=currProduction;    
  }    
}
return result;  

SplicingSql SQL拼接

javascript 复制代码
var result={sql:""};
console.log(result);
var Cid=$('ParseDataPackets').first().json.Cid;
var Countstr=String($('ProductionCale').first().json.Count);
if ($input.first().json.hasOwnProperty(Cid)){
  var cfg=$input.first().json[Cid];
  result.sql=`update PLC_T_Data set Sys_time=NOW(),PLC_time=NOW(),${cfg.plc}=${cfg.plc}+${Countstr} where devID=${cfg.devid}`;
}
console.log(result);
return result;

Redis的使用

在产量计算过程中,需要通过redis节点读取上一次产量,redis节点存储当前产量;n8n有全局变量,但使用过程中并不能持久化,使用redis更好;

redis写入节点

通过Redis读写数据,然后通过redis客户端,能提供很好的数据观测性

相关推荐
程序员老赵1 小时前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua1115 小时前
LM Studio Docker 部署——本地大模型一键启动
docker
曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
武子康3 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
Alsn866 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
程序员老赵6 天前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
杨浦老苏6 天前
轻量级Docker仪表板Servedash
运维·docker·监控·群晖·仪表板
正经教主6 天前
【docker基础】 第八周:容器监控与应用更新策略
运维·docker·容器
kiros_wang6 天前
Docker 使用完整指南
运维·docker·容器
正经教主6 天前
【docker基础】第九周:Docker安全与镜像优化
运维·docker·容器