×

通过AWS IoT控制连接到Intel Galileo Gen 2的事物

消耗积分:0 | 格式:zip | 大小:0.31 MB | 2023-02-02

刘军

分享资料个

描述

该项目演示了访问和控制各种组件,例如 LED、蜂鸣器、按钮、温度传感器和光传感器。这个项目可以很容易地扩展到家庭自动化。AWS IoT 控制台的 MQTT 协议用于实现此目的。MQTT 是一种广泛应用于物联网项目的机器对机器消息传递协议。该协议具有 MQTT Broker(服务器)和 MQTT 客户端。在我们的案例中,AWS IoT 充当安全的 MQTT Broker,而 Intel Galileo 充当 MQTT 客户端。MQTT 遵循发布者-订阅者模型。发布到主题的消息将在订阅该主题的所有客户端中接收。因此,使用 MQTT 可以轻松实现双向通信。

 

平台说明:

  • AWS IoT 控制台:Amazon Web Services 最近推出了对 IoT 的支持。与其他开源和免费平台相比,它是一个非常安全的平台。在将数据发布到云端之前,您必须先注册您的设备并下载证书。
  • Intel Galileo Gen 2:Galileo 是一款基于 x86 SoC 的嵌入式开发板,带有 Arduino 引脚输出。您可以将开发板用作 Arduino 或用作嵌入式 Linux 平台。它运行 Yocto-Linux 发行版。
  • Grove 入门套件:Grove 是一款易于使用的学习套件,专为 Intel 和 Arduino 开发板设计。它包含现成的组件,如蜂鸣器、光传感器、继电器模块等。该项目将涵盖几个组件,但其他组件可以通过修改源代码轻松控制。

 

设置硬件:

Sparkfun 有一个非常好的入门指南使用以太网或 WiFi 将您的伽利略板连接到互联网。对于 WiFi 设置,您必须使用 connmanctl 命令行。一旦能够登录到 Linux 终端,就需要下载一些必要的库。

用于节点 js 的 AWS IoT 库:通过绑定命令安装 

$ npm install aws-iot-device-sdk

 

连接 x86: 按顺序键入以下命令进行安装:

$ mkdir wiringx86-src
$ cd wiringx86-src
$ curl -O -L http://github.com/emutex/wiring-x86/archive/master.tar.gz
$ tar zxvf master.tar.gz
$ cd wiring-x86-master/
$ sudo python setup.py instal

 

设置 AWS 物联网:

在 Amazon Webservices 中创建一个帐户并导航到 AWS IoT 控制台。如果您是新用户,您将看到此页面。单击“开始”。

1.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

给客户端或设备名称,将属性留空,然后按创建按钮。

2.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

该事物将显示在您的仪表板中。单击事物(在我的例子中是 intel_galileo)。它将在右侧加载一个小窗口。

3.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

按连接设备按钮。这将指导您将新设备连接到 Thing。此步骤将为您的设备生成公钥、私钥和证书。

3.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

由于 Intel Galileo 官方 Yocto 映像带有 NodeJS 和 Python,我们将选择我们的 sdk 作为 NodeJS。现在单击生成证书和策略。

4.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

将所有文件下载到您的计算机,然后按确认并开始连接。

5.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

下一个屏幕将向您显示连接详细信息的 JSON 格式。记下它。

6.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

为 AWS 配置英特尔伽利略:

通过 SSH 登录英特尔伽利略终端。(我对 SSH使用Putty ,对 SCP使用WinSCP )

通过键入以下命令为 AWS 创建一个新文件夹:

$ mkdir aws-iot
$ cd aws-iot

创建一个文件夹来放置证书:

$ mkdir cert
$ cd cert

使用 WinSCP 工具将下载的证书移动到文件夹 cert。

7.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

在终端中使用ls命令验证证书是否正确放置。请注意,您的证书和密钥名称的开头可能不同。 

8.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

 

除了上述证书和密钥外,我们还需要来自 Symantec 的密钥。您可以使用以下命令下载它:

$ curl https://www.symantec.com/content/en/us/enterprise/verisign/roots/VeriSign-Class%203-Public-Primary-Certification-Authority-G5.pem  > rootCA.pem

将 Intel Galileo 连接到 AWS IoT:

在此步骤中,我们将向 AWS IoT 控制台注册我们的设备。将文件下载connectToAWS.js到您的计算机并使用 WinSCP 移动到 Intel Galileo 的 aws-iot 文件夹。

请注意,您必须根据您的帐户更改证书名称、密钥和区域名称。

使用命令运行文件

$ node connectToAWS.js

如果您正确执行了所有步骤,您将看到类似这样的内容。

9.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

看到以上输出后,请按Ctrl+C 终止程序。

转到您的 AWS IoT 控制台并选择 intel_galileo。按更新 Shawdow 按钮。您会找到您的 Intel Galileo 的本地 IP 地址。恭喜!您已成功将您的设备连接到 AWS IoT。

10.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

通过 AWS IoT 控制事物:

这是该项目的有趣部分。我们将在 Galileo 和 AWS 之间来回通信。

将 Grove shield 连接到 Intel Galileo 并进行以下连接:

温度传感器 --> A0

光传感器 --> A1

按钮 --> D2

蜂鸣器 --> D3

发光二极管 --> D4

 

 

将 controlThings.py 保存在您的 aws-iot 文件夹中。确保更新您的证书和服务器地址。服务器地址因用户而异。在这里能找到它:

11.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

通过键入以下命令运行该程序:

$ python controlThings.py

该程序将每 10 秒向 AWS IoT 发布一次温度和光传感器值。它还会持续监视按钮是否被按下。如果按下按钮,消息将发布到 AWS。

要查看消息,请转到 AWS IoT 控制台并单击 MQTT 客户端选项。

输入客户端 ID 和 intel_galileo,然后按连接。

13.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

选择订阅主题并输入主题名称 things/temp

对 things/light 和 things/button 重复相同的步骤。

您将能够看到三个不同的主题选项卡。

15.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

很快,每隔 10 秒,您就可以看到温度和光照值不断增加。此外,当您按下按钮时,“按下按钮”消息将发布到 AWS。

16.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
您可以看到每 10 秒接收一次温度值
 

 

17.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

我们已经实现了 Intel Galileo 和 AWS IoT 之间的通信。让我们看看如何通过 AWS IoT 控制连接到 Intel Galileo 的东西。

为此,您必须向必要的主题发布消息。在 python 中,您可以看到我们订阅了主题 things/buzzer和 things/led。

在 AWS IoT 控制台中选择发布到主题并输入 things/buzzer。输入信息:

{"Period" : 2, "PWM" : 200}

并按下发布。您将听到两秒钟的蜂鸣声。

18.PNG?auto=compress%2Cformat&w=740&h=555&fit=max
 

请尝试以下消息:

{"Period" : 5, "PWM" : 120}

您将听到 5 秒钟的声音,但这次声音会有所不同,因为我们更改了 PWM 值。

同样,您可以通过在 things/led 中发布消息来控制 LED

例如: {"Period" : 1, "loopFor" : 10}

这将使 LED 每 1 秒闪烁 10 次。通过改变这些值来玩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'通过AWS IoT控制连接到Intel Galileo Gen 2的事物',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);