写点什么

第 3 部分:连接您的无人驾驶车辆

  • 2019-11-06
  • 本文字数:3453 字

    阅读完需:约 11 分钟

第 3 部分:连接您的无人驾驶车辆

在我们无人驾驶车辆系列的第一篇博客文章中,您制作了一辆 Donkey 车并将导航服务器部署到 Amazon EC2 实例上。在第二篇博客文章中,您学习了如何驾驶 Donkey 车辆,Donkey 车辆也学习了如何自行驾驶。在这篇博客文章中,我们将介绍将 Donkey 车辆的遥测数据流式传输到 AWS 的过程。all 我们将使用 AWS IoT 服务,因为该服务提供了一组可扩展、可靠并且功能丰富的服务,这些服务可用于所有种类的互连设备,包括我们的互联车辆。




  1. 在 AWS 上制造一辆无人驾驶车辆,并参加 re:Invent 机器人车拉力赛

  2. 《制作无人驾驶车辆》第 2 部分:驾驶您的车辆

  3. 《制作无人驾驶车辆》第 3 部分:连接您的无人驾驶车辆

  4. 即将推出



AWS IoT 设置

无人驾驶车辆在驾驶过程中会生成持续的遥测数据流。车辆不在驾驶状态时,没有遥测数据可收集,所以我们不希望耗用任何资源,避免浪费。为适应工作负载的变化,我们计划依靠无服务器技术为整个架构提供支持。首先,我们将使用 AWS IoT 设计一项车队监控服务。它可以使用同一基础架构为任意数量的车辆提供服务。下图显示了该车队监控服务的架构。



此解决方案的组件按逻辑功能 (和 AWS 服务) 进行颜色编码,以展示解决方案每个组件的安全性、可扩展性和完全基于使用量的特点。这种运营模型适合很多业务模式,对任何规模的客户都有用。无论是要跟踪和比较圈速的无人驾驶车辆业余爱好者,还是希望开发其自己的互联车辆平台的无人驾驶汽车制造商,都可以使用 AWS IoT 提供的安全、可扩展且基于使用量的成本结构。


此解决方案以 Donkey 车辆 (绿色阴影所示) 开始。接下来数据通过 IoT 服务传递到粉色部分,在 DynamoDB 中进行短期存储,然后传递到蓝色部分,在 S3 中长期存储。此外,AWS IoT 主题中的数据也可以实时查询并 (如下所示) 用于驱动控制面板。


Donkey 车辆已连接 Internet,这意味着它能够将遥测数据流式传输到一个集中位置,本例中为 AWS IoT。为保证遥测数据的安全,我们将从 AWS IoT 生成证书并将证书部署到 Donkey 车辆。通过使用证书,Donkey 车辆可通过 MQTT 使用 TLSv1.2,与 AWS IoT 进行安全通信。MQTT 是一个极其轻量的协议,能够很好地应对低信号网络,因此可以解决连接可靠性难题。


保证安全的最简单方法是使用一键式证书创建方法。为此,请打开 AWS IoT 控制台。在左侧导航窗格中,选择“Security”。然后,选择 Create 按钮。

创建证书

可以使用 AWS IoT 控制台、AWS IoT API 创建证书,也可以像我们在上一篇博客文章中那样在 Raspberry Pi 上使用 Amazon EC2 Systems Manager Run Command 生成并传输证书。通过使用 EC2 Systems Manager 执行此过程,我们无需手动将证书复制到 Raspberry Pi。


为简便起见,我们将使用 AWS IoT 控制台完成此过程。


我们将创建一个新策略,通过它向我们的 Donkey 车辆授予对 AWS 服务的特定权限。这允许我们设置精细的车辆特定设置,如可以访问的 AWS IoT 主题和可以采取的 IoT 操作。


首先打开您的 AWS 管理控制台。转到 AWS IoT 控制台并选择“Security”,然后选择 Policies。然后选择 Create


我们将使用此策略来允许对 AWS IoT 服务执行所有操作,因为我们不需要阻止使用该服务的完整功能。此特权包括:iot:Publish、iot:Subscribe、iot:Connect、iot: Receive、iot:UpdateThingShadow、iot:GetThingShadow 和 iot:DeleteThingShadow。



除证书和策略外,AWS IoT 服务还需要创建一个事物来描述我们的 Donkey 车辆。为此,在左侧的导航窗格中,从注册表中选择“Things”。然后选择 Create,为您的事物提供一个名称并单击 Create thing



现在已经创建了策略和事务,我们可以将它们与之前创建的证书相关联。为此,请在左侧导航窗格中选择“Security”、“Certificates”。找到并选中您之前创建的证书。从 Actions 菜单中,选择 Attach Policy。然后从 Actions 菜单中,选择 Attach Thing


AWS IoT 规则

现在我们有了生成和传输遥测数据的方法,可以专心构建该解决方案的其余功能了。我们的解决方案需要两个规则,一个用于控制面板要访问的 Amazon DynamoDB,另一个用于 Amazon Kinesis Firehose,它将所有遥测数据分发给 Amazon S3 和 Amazon Kinesis Analytics 以便进行实时遥测数据分析。

DynamoDB 规则

首先,我们将创建用于 DynamoDB 的规则。在 AWS IoT 控制台左侧的导航窗格中,选择“Rules”。然后选择 Create 按钮。


Create a rule 页面上,为规则输入名称并添加描述,描述要能轻松标识数据的类型和使用这些记录的 AWS 服务。



然后选择 Add actionSplit message into multiple columns of a database table (DynamoDBv2)



然后选择 Configure action


接下来,您可以创建新表或使用现有表。我们将选择 Create a new resource 创建一个新表。


现在我们按照 Create DynamoDB table 向导操作。我们调用 Table name AutonomousVehicles,将 Primary key (分区键) 设为 vehicleID 属性,该属性在该车队中的所有车辆中是唯一的。我们将对属性时间添加一个排序键,从而提高 DynamoDB 查询效率。其他设置保留默认值。对于处理一辆车的遥测数据来说,这些已经足够了。



在 DynamoDB 创建表的同时,我们可以设置 TTL 属性以将 DynamoDB 的运行成本保持在非常低的水平。如果您保留默认的 5 个读取容量单位 (RCU) 和 5 个写入容量单位 (WCU),月度账单大约为 2.50 USD。RCU 和 WCU 可以手动上下调整,或者,您也可以选择使用 Auto Scaling。为了降低成本,我们还将允许 DynamoDB 根据用户定义的属性自动让项目过期。在这里,我们将向遥测添加 TTL 时间戳。在我们在 Donkey 车辆上运行的程序中,我们将把 dynamodb_ttl 属性设置为当前 Unix 时间戳加上 2592000 (30 天),然后将其存储在 DynamoDB 中。30 天后,DynamoDB 会知道 TTL 属性已过期并自动删除这些项目。



选择 Continue 以启用 TTL。返回您执行 AWS IoT 配置操作时离开的页面,从 Table name 下拉列表中选择您的表。如果看不到您的表,请单击刷新箭头。然后,选择 Create a new role 并将其命名为 AutonomousVehiclesDynamoDB 或类似名称。选择 Update role,然后选择 Add action


接下来我们可以检查一下我们的所有选择。准备好后,选择 Create rule

Kinesis Firehose 规则

现在我们可以按照类似的步骤创建另一个规则以将所有遥测数据发送到 Kinesis Firehose。在左侧导航窗格中,选择“Rules”。然后选择 Create 按钮。


Create a rule 页面上,为规则输入名称和描述,描述要能轻松标识数据的类型和使用这些记录的 AWS 服务。



然后选择 Add action,再选择 Send messages to an Amazon Kinesis Firehose stream



然后选择 Configure action


现在需要做一个选择:创建新流还是使用现有流。我们将选择 Create a new resource 以创建一个新流。


我们现在按照 Create delivery stream 向导操作并为传输流提供一个名称。选择 Next




选择 Next



确保选中了 Amazon S3。选择要将遥测数据存储到其中的相应 S3 存储桶和前缀。



为 IAM 角色选择 Create new 或选择。 从下拉列表中,选择“Create a new IAM Role”并为其提供一个角色名称。选择 Allow。然后选择 Next




最后,确认一切正确无误并选择 Create delivery stream



返回 Configure action 屏幕并选择所创建的新流。


然后选择 Create a new role,AWS IoT 将用该角色访问 Amazon Kinesis Firehose 流。为角色命名后,选择 Update role,然后选择 Add action



最后,确认所有选择,准备就绪后选择 Create rule



AWS IoT 服务现已就绪,正在等待遥测数据的流入。由于 AWS IoT 是无服务器并基于使用量的服务,所以其部署和保持开启不会产生任何费用。Amazon Kinesis Firehose 和 Amazon S3 也是根据数据摄入量计费的。现在,我们可以生成遥测数据,然后使用 AWS IoT 控制台检查它是否发送到正确的主题。



或者,我们也可以构建一个控制面板来直接连接到 AWS IoT,使它可以近乎实时地使用这些遥测数据。下面是一个控制面板的示例,它托管在 Amazon S3 上,因此完全无服务器并且无需管理底层 Web 服务器。在下面的教程中可找到可视化 IoT 遥测数据的示例:


部署端到端 IoT 应用程序 (pdf)


以下博客文章中也有相关内容:


使用 Amazon Kinesis Analytics 和 Amazon QuickSight 为 IoT 数据构建可视化和监控控制面板



在下一篇博客文章中,我们将回顾到目前为止我们做过的所有工作,并讨论关于无人驾驶车辆的下一步行动。


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/building-an-autonomous-vehicle-part-3-connecting-your-autonomous-vehicle/


2019-11-06 08:00601

评论

发布
暂无评论
发现更多内容

模块一作业

bin

apipost使用脚本发送一个接口请求

与风逐梦

后端 开发工具 接口测试

架构实战训练营模块 1 作业

斯蒂芬.赵

架构实战营

深入虚拟机探索Thread start

4ye

源码 线程 后端 JVM 8月日更

Vue进阶(七十二):css 样式中 逗号、空格、冒号、点号、~、>的区别

No Silver Bullet

Vue 8月日更

架构实战☞ 微信业务架构&学生管理系统架构设计

眼镜盒子

架构实战营

故事篇:数据库架构演变之路

阿Q说代码

主从复制 读写分离 集群部署 8月日更 垂直拆分

作业

Doctor Blind

架构实战营

一文为你介绍ServiceComb Service-Center三大高性能优化点

华为云开发者联盟

开源 微服务 注册中心 Service-Center

常见内存泄漏引起原因

金陵老街

新生代农民工的十八般武艺,你都了解吗

华为云开发者联盟

DevOps 云原生 编程语言 编程规范 新生代农民工

微服务的痛:用实际经历告诉你它有多坑(三)

我爱娃哈哈😍

微服务 架构设计

模块一

Tim

架构实战营

拆分电商系统为微服务

tjudream

微服务 电商 拆分

linux笔记:极简方式安装mysql,建议收藏

小鲍侃java

8月日更

架构实战营模块一作业

李焕之

云小课|想实现资源全自动备份?看完这篇秘籍,不再蕉绿~

华为云开发者联盟

云备份 自动备份 备份策略

深入了解现代web浏览器(第二部分)

GKNick

大前端 浏览器

如何在 MacOS 上降级 Java 版本

escray

学习 8月日更

模块1作业

atob

架构实战营-模块一作业

Alex.Wu

架构实战课程 模块一作业

Frank

百度地图开发-与地图的交互功能 06

Andy阿辉

android Android Studio Android 小菜鸟 8月日更

在线JSON转HTML,TABLE表格工具

入门小站

工具

微信朋友圈高性能复杂度分析

刘琦Logan

Pulsar 周报 2021-08-09 ~ 2021-08-15

Apache Pulsar

Apache Pulsar StreamNative

模块一作业:微信业务架构图与学生管理系统毕设架构设计

apple

模块一作业

Geek_85eb5f

0基础架构入门 - 1(架构概述)

felix

架构实战营 0基础架构入门

TP6+layui2.6.8开发的管理系统(FunAdmin),内置Curd命令模式 在线更新

funadmin

CMS layui 商城 管理系统 funadmin

面试侃集合之SynchronousQueue非公平模式篇

码农参上

非公平锁 SynchronousQueue 8月日更

第 3 部分:连接您的无人驾驶车辆_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章