.. | ||
etc | ||
include | ||
priv | ||
src | ||
test | ||
.gitignore | ||
erlang.mk | ||
LICENSE | ||
Makefile | ||
README.md | ||
rebar.config |
本项目将通过实战的形式展示如何通过数蛙工业物联网Saas平台开发自己的行业插件应用,并能基于自己的行业插件模型,开发自己的行业云函数,逐步成长为行业专家.
本来想通过一个虚拟的项目来进行讲解,由于当前有好几个客户项目需要用到过电表集抄,考虑到电表集抄应用非常广泛,就以电表为例进行来展开数蛙工业物联网Saas平台第一个开源项目培训。
一点心得
这几年在物联网项目中爬坑的一点心,套用道家几句话,希望能对您今后的工业物联网实践有帮助
- 顺其自然
调研阶段要多观察,抓住物理层本身的规律,抓住事物的本质,不要凭空胡思乱想
- 清净无为
设计阶段要如庖丁解牛,顺着物理层本身关系,去映射虚拟层,不要凭空添加路由
- 万物均衡
运营阶段要不偏不倚, 在时空维度上做好均衡,进行各种削峰处理,保持长期稳定运行
典型案例是陶总在时间维度对物的观察创造了Tdengine,Joe Armstrong在空间维度对物的观察创造了Erlang
用户场景
从用户到设备,主要需要解决如下几个问题:
-
人与设备的关系,User基于流动性,权限系统里一般不会直接绑定User与Device的权限关系,中间会通过Department(Role)来间接绑定ACL
-
设备与设备的关系,设备与设备之间有可能存在真实的关系,例如DTU与Meter,也可能只有一种虚拟关系,例如Group与DTU,属于因工程需要,临时拉群
-
对具体设备来说,1、需要一个UID来表征身份;2、需要一个route来表征关系;3、需要多个tag来表征特征
-
重点讨论Meter、DTU和TCP Server的交互过程
No. 名称 Meter DTU TCP Server 说明 1 连接 send -> [IP] ack <-- [IP] 必选 2 登陆 send -> [DtuAddr] ack <-- [DtuAddr] 可选,可用IP代替 3 扫串口 ack-> [485] send <-- [search 485] send <--[search 485] 可选,有档案可免 4 扫modbus ack-> [modbus] send <-- [search modbus] send <--[search modbus] 可选,有档案可免 5 扫表 ack-> [Meter Addr] send <-- [search meter] send <--[search meter] 可选,有档案可免 6 抄表 ack-> [Meter Data] send <-- [read meter] send <--[read meter] 必选 7 写表 ack-> [Meter Control] send <-- [write meter] send <--[write meter] 可选 8 登出 send -> [DtuAddr] ack <-- [DtuAddr] 可选 9 断开 send -> [IP] do_something 必选 扫串口、扫描modbus、扫表是一个费时费流量的操作,例如扫表一般至少需要扫256次,一般只会在物联网工程施工阶段进行,并完成相应的自动注册功能,形成设备档案,正常运行中不进行这些操作。
这也是为什么电力抄表非常强调电表档案建设,如果没有档案,每一次DTU掉线都需要重新进行非常耗时耗流量的扫描任务
整体交互流程如下
---------------------------------------------------------------------------------------------------------------------
| 物理层 | 连接层 | 虚拟层 | 应用层|
---------------------------------------------------------------------------------------------------------------------
User1(Session) User2(Session)
| |
API API <--http--> dgiot_rest --+
| | |
+ + |
Department1(Role) Department2(Role) |
| | |
ACL ACL <--parse--> shuaw_parse --+
+ + | +-- 时序数据--+
Group(Devcie) Group(Devcie) | | |
| | | === 流计算==> 物理层镜像 +--> 批量计算
+--------+-------+ + | | |
| | | | +-- 关系数据--+
DTU1(Device1) DTU2(Device) DTU3(Device) <--tcp--> tcp_server ---+
| | | |
modbus modbus modbus <--modbus--> proctol ---+
| | | |
+ + + |
485 485 485 <--485--> proctol --+
| | | |
+ + +--------+--------+ |
| | | | |
Meter1(Device) Meter2(Device) Meter4(Device)Meter5(Device)<--DLT/645--> proctol --+
在正式动手之前,请先体会一下心得和理解用户场景
培训纲要
- 学会创建一个部门
- 学会创建一个岗位
- 学会创建一个用户
- 学会创建一个应用
- 学习创建一个API
- 学会创建一个分组
- 学会创建一个产品
- 学会创建一个设备
- 学会创建一个指令
- 学会创建一个子设备
- 学会创建一个物模型
- 学会创建一个组态
- 学会创建一个通道
- 学会创建一个规则
- 学会开发一个插件
- 学会接入一个设备
- 学会设计一个统计量
- 学会状态迁移编程
- 学会网络通信编程
- 学会消息路由编程
- 学会设备动态注册