dgiot/apps/dgiot_meter/README.md

100 lines
6.4 KiB
Markdown
Raw Normal View History

2021-07-05 17:29:05 +08:00
本项目将通过实战的形式展示如何通过数蛙工业物联网Saas平台开发自己的行业插件应用,并能基于自己的行业插件模型,开发自己的行业云函数,逐步成长为行业专家.
本来想通过一个虚拟的项目来进行讲解由于当前有好几个客户项目需要用到过电表集抄考虑到电表集抄应用非常广泛就以电表为例进行来展开数蛙工业物联网Saas平台第一个开源项目培训。
# 一点心得
这几年在物联网项目中爬坑的一点心,套用道家几句话,希望能对您今后的工业物联网实践有帮助
+ 顺其自然
调研阶段要多观察,抓住物理层本身的规律,抓住事物的本质,不要凭空胡思乱想
+ 清净无为
设计阶段要如庖丁解牛,顺着物理层本身关系,去映射虚拟层,不要凭空添加路由
+ 万物均衡
运营阶段要不偏不倚, 在时空维度上做好均衡,进行各种削峰处理,保持长期稳定运行
典型案例是陶总在时间维度对物的观察创造了TdengineJoe 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(DeviceMeter5(Device<--DLT/645--> proctol --+
```
在正式动手之前,请先体会一下心得和理解用户场景
# 培训纲要
- 学会创建一个部门
- 学会创建一个岗位
- 学会创建一个用户
- 学会创建一个应用
- 学习创建一个API
- 学会创建一个分组
- 学会创建一个产品
- 学会创建一个设备
- 学会创建一个指令
- 学会创建一个子设备
- 学会创建一个物模型
- 学会创建一个组态
- 学会创建一个通道
- 学会创建一个规则
- 学会开发一个插件
- 学会接入一个设备
- 学会设计一个统计量
- 学会状态迁移编程
- 学会网络通信编程
- 学会消息路由编程
- 学会设备动态注册
# 详细步骤