SANSAN新鲜事|一文搞懂IOT平台的数据采集架构

2024-03-03 17:30

本文主要是介绍SANSAN新鲜事|一文搞懂IOT平台的数据采集架构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本专栏的上一篇文章“场站数字化避坑指南”中提到,场站数字化实施所遇到的“坑”中,其中一个是:传感器协议种类多且复杂,会导致系统架构复杂,最终系统难以实现、BUG多、工期长。想避免这种问题,需要抽象一个高内聚、低耦合、易于扩展和维护的数据采集架构。今天,本文就来聊一下,什么是一个合理的数据采集架构。

首先插播一个广告:三三是一个开源的物联网平台,代码可以商用而无限制,欢迎访问

什么是数据采集架构

数据采集架构是物联网平台技术架构的组成部分,主要负责数据采集,也就是从各种IOT设备上收集数据。这部分功能是任何物联网应用的核心组成部分。没有这部分功能,物联网应用就是无源之水、无本之木。

数据采集架构的组成部分

我们从架构的最下层开始,看看数据采集架构应该包含哪些组成部分。

物理设备

数据采集的对象,比如传感器、PLC、控制器、机床、智能灯/锁/开关等各种IOT设备。

设备协议

物理设备传输数据的协议,比如工业上的Modbus、西门子S7、OPCUA;电力领域的DL/T645、IEC104;水利的SL651;视频传输的国标协议GB28181。

网关

网关的含义特别杂,比如DTU、WiFi路由器都被叫做网关;工业中各种协议转换的盒子,被叫做网关;有的电脑部署了一个代理软件,也被叫做网关。究其根本,网关的本质就是做协议转换,从最底层的物理层协议到最上层的应用层协议,各种网关不过是对应在协议栈的不同层上做转换。比如工业数采网关实现的是工业协议到平台协议的转换;WiFi路由器实现的是WiFi到以太网的转换。

连接

负责将物理设备的数据通过网络传输到上层软件平台,它可能包括各种通信技术,如以太网、Wi-Fi、蓝牙、Zigbee、LTE、5G等。

平台

物联网平台负责将设备数据收集上来、处理和存储。而为了适配不同的设备协议,IOT平台需要在架构上进行合理的抽象,一般都会抽象出设备、网关、产品这几种对象,以及制定物模型、平台协议作为设备模型、接入设备的标准通信协议。

三三物联网平台的数据采集架构

三三在沿用一般IOT平台的基本抽象(设备、网关、产品)的基础上,有着自己独特的创新,真正将数据采集架构做到了简洁和优美,能够非常方便的扩展各种设备接入方式。比如三三将软网关和硬网关的做了很好的统一,对三三而言,软网关和硬网关甚至可以相互转换,比如你将软网关部署到了盒子里,它就变成了硬网关。

三三物联网平台接入设备示例

正是由于三三简洁的数据采集架构,基于三三开源物联网平台,众多开发者已经轻松扩展适配了数百种设备,以下是一些示例:

空调:

智能锁:

摄像头:

电表:

本文到这里就结束了,欢迎您也作为开发者,使用三三开源物联网平台接入您自己的设备,搭建属于您自己的物联网应用。

关注宏电官方微信公众号

每周三带您了解不一样的SANSAN开源物联网平台

这篇关于SANSAN新鲜事|一文搞懂IOT平台的数据采集架构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/770365

相关文章

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

Linux之platform平台设备驱动详解

《Linux之platform平台设备驱动详解》Linux设备驱动模型中,Platform总线作为虚拟总线统一管理无物理总线依赖的嵌入式设备,通过platform_driver和platform_de... 目录platform驱动注册platform设备注册设备树Platform驱动和设备的关系总结在 l

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断