物联网平台设备数据同步到RDS & MySQL数据库(保姆级教学)

物联网平台设备数据同步到RDS & MySQL数据库(保姆级教学)

 

目标实现:

阿里云物联网平台某设备实时数据(MQTT协议上云)同步存储到RDS MySQL数据库

 

实现步骤:

注意:以下实现默认MQTT上云已经完成,可实时上传数据

1、物联网平台接收到数据通过规则引擎转发至DataHub。

2、在DataHub中通过DataConnector将数据同步到RDS MySQL数据库中

阿里云教程概述
请添加图片描述

 

细节!!!拿来吧你!

 

1、创建RDS MySQL数据库表

这步的依据是什么?

答:物联网平台的设备有什么数据?以我这边的情况为例,有甲醛、PM2.5。

请添加图片描述

请思考:是不是现在新建一张数据表,表中创建两个就可以字段,分别是HCHO(甲醛)、PM25(PM2.5)就可以了呢?

答:表结构实际上有点问题,因为这样的话那主键未明确,后面还要查出来看的,不单单是存着就好,于是这里决定再加一个字段id作为主键(或许也可考虑复合主键,),并设置自动递增,因为原设备上云数据中没有对应id的值,然后可以再加两个字段create_time 和 devicenamecreate_time 和 devicename的值可通过阿里云内置函数获取,后面会讲到。

请添加图片描述

至此,第一步就完成了

 

2、创建DataHub项目

DataHub通俗理解:它是一条线,把两个阿里云的产品连起来,通过一些转发规则完成产品之间的数据流转(我瞎扯的可能不准确,具体可看官网文档)

1、开通服务(有个梗:这游戏求你下一个吧,不用钱好吧)

2、创建项目

请添加图片描述

点击新建项目,随便填,我这里填项目名alice_air

请添加图片描述

3、新建Topic

Topic通俗理解:一个话题,物联网平台后面需要去订阅这个话题,把数据同步到Datahub

请添加图片描述

4、同步到RDS MySQL数据库

注意:我这里先配完DataHub同步数据库,后配置物联网同步到DataHub,当然你也可以先配物联网同步到DataHub,看看DataHub有没有实时流量显示

点击查看

请添加图片描述

点击同步

请添加图片描述

选择RDS & MySQL

请添加图片描述

新建Connector(配置对应的MySQL Host,数据库、数据表)

请添加图片描述

至此,第二步也完成了。

 

3、规则引擎

这步是为了把物联网平台数据转发到DataHub

1、云产品流转

请添加图片描述

2、创建规则

请添加图片描述

3、选择json(我这边设备数据是通过json格式上云)

请添加图片描述

4、编写SQL

请添加图片描述

请添加图片描述

5、转发数据到DataHub,添加规则

请添加图片描述

请添加图片描述

注意:${key},key是什么,key就是编写SQL时,as xxx 的那个xxx

items.HCHO.value as HCHO ==> ${HCHO}

最后确定,完美撒花?NO,注意,记得启动,这下应该完美撒花了。

请添加图片描述

经过以上步骤,如果数据库并没有新增任何数据记录,可一步一步排查问题。

1、先确定设备数据是不是在实时上传,在物联网平台查看设备物模型数据

2、看看DataHub有没显示实时流量数据,没有的话说明云产品流转这块没弄好

3、如果DataHub有数据流量显示了,说明很可能是配置MySQL数据库有问题,看看账号密码,host地址,和网络类型等。

  • 4
    点赞
  • 92
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
这个问题涉及到两个方面的内容,一个是如何读取阿里云物联网平台数据,另一个是如何读写阿里云RDS数据库。下面我分别进行解答: 1. 如何读取阿里云物联网平台数据? 阿里云物联网平台提供了多种接入方式,包括 MQTT、HTTP、CoAP 等。其中 MQTT 是最常用的一种接入方式,也是阿里云物联网平台官方推荐的接入方式。在 MATLAB 中,可以使用 MATLAB 自带的 mqtt 函数库来实现 MQTT 协议的订阅和发布。 首先需要在阿里云物联网平台上创建一个设备,获取到设备的三元组信息(ProductKey、DeviceName 和 DeviceSecret)。然后使用 mqtt 函数库连接到阿里云物联网平台的 MQTT 服务器,并订阅设备的 Topic,就可以收到设备上报的数据了。具体的代码如下: ```matlab % 阿里云物联网平台 MQTT 服务器地址 broker = 'tcp://xxxxx.iot-as-mqtt.cn-shanghai.aliyuncs.com'; % 设备三元组信息 productKey = 'xxxxxxxxxxxxx'; deviceName = 'xxxxxxxxxxxxx'; deviceSecret = 'xxxxxxxxxxxxx'; % MQTT 连接选项 options = mqttv5_options('UserName', productKey + '/' + deviceName, ... 'Password', mqtt_password(productKey, deviceName, deviceSecret), ... 'CleanSession', true, ... 'ConnectTimeout', 30); % MQTT 订阅选项 subscription = mqttv5_subscription(topic, 1); % 连接 MQTT 服务器并订阅 Topic client = mqttv5(broker, options); subscribe(client, subscription); % 循环获取设备上报的数据 while true message = receive(client); data = message.Payload; % 处理数据 ... end % 断开 MQTT 连接 unsubscribe(client, subscription); disconnect(client); ``` 2. 如何读写阿里云RDS数据库? 阿里云RDS是一种云数据库服务,支持多种数据库类型,包括 MySQL、SQL Server、PostgreSQL、PPAS 等。在 MATLAB 中,可以使用 MATLAB 自带的 Database Toolbox 函数库来连接阿里云RDS数据库,并进行数据的读写操作。 首先需要在阿里云RDS上创建一个数据库实例,并开通相应的数据库服务。然后使用 Database Toolbox 函数库连接到阿里云RDS数据库,并执行 SQL 查询语句或更新操作即可。具体的代码如下: ```matlab % 阿里云RDS数据库连接选项 driver = 'com.mysql.jdbc.Driver'; url = 'jdbc:mysql://xxxxxxxxxxxx.rds.aliyuncs.com:3306/xxxxxxxxxxxx'; username = 'xxxxxxxxxxxx'; password = 'xxxxxxxxxxxx'; % 连接阿里云RDS数据库 conn = database('xxxxxxxxxxxx', username, password, driver, url); % 执行 SQL 查询语句 query = 'SELECT * FROM xxxxxxxxxxxx'; curs = exec(conn, query); data = fetch(curs); % 执行 SQL 更新操作 query = 'UPDATE xxxxxxxxxxxx SET xxxxxxxxxxxx = xxxxxxxxxxxx WHERE xxxxxxxxxxxx = xxxxxxxxxxxx'; curs = exec(conn, query); % 关闭数据库连接 close(curs); close(conn); ``` 以上是在MATLAB中读取阿里云物联网平台数据并读写阿里云RDS数据库的基本操作,具体实现还需要根据具体情况进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值