Create 20170718 Things to consider when building a robot with open source.md

This commit is contained in:
SunWave 2017-07-30 16:57:39 +08:00 committed by GitHub
parent a527003908
commit 5403018dde

View File

@ -0,0 +1,23 @@
使用开源构建机器人时需要考虑的事项
或许你正在考虑或正在进行将机器人使用开源软件推向市场。这个机器人是基于linux构建的。也许你正在使用机器人操作系统ROS或任务导向的操作套件MODS或者是另外一个可以帮助你简化开发过程的开源中间件。当开发接近实用化期望得到回报会开始给你带来一些压力。你可能会被问到“我们的产品什么时候可以开始销售这时你将面临重要的抉择。
你可以做下面两件事之一:
1.对现有的产品开始出货
2.回过头去,把现在的产品当做一个全新的问题来解决,并提出新的问题
不需要看很远就可以找到采用1的例子。事实上在物联网设备市场上到处都是这样的设备。由于急于将设备推向市场在这些设备中找到硬编码证书、开发密钥、各种安全漏洞和没有更新方式的产品并不少见。
想想Mirai僵尸程序通过僵尸网络发起一个网络流量超过1Tbps的分布式拒绝服务攻击DDos导致一些互联网上最大的网站停止服务。这个僵尸网络主要由物联网设备组成。这种为了攻破设备的防御机制进而控制设备所开发的僵尸程序是采用了超级酷的黑魔法在一个无窗实验室或地下基地开发的吗不是默认的通常是硬编码证书。这些设备的制造商是否快速反应并发布所有这些设备的更新以确保设备的安全很多制造商根本没有更新方法。他们会开始反思。
不是急于将产品推向市场,而是退后一步。多思考几点,就可以使你自己和你所在公司避免痛苦。
例如你的软件如何更新这必须能回答这个问题。你的软件不是完美的。几个星期之内当你在加利福尼亚使用自主的高机动性多用途轮式车辆HMMWV它把小灌木识别为一棵橡树。或者你不小心在软件中包含了你的SSH密钥。
基础操作系统如何更新也许这仍然是你的产品的一部分也是你回答上一个问题的答案。但也许你使用的操作系统来自于另外一个供应商。你如何从供应商那里得到更新并提供给客户这就是安全漏洞真正让你头痛的地方从来不更新的内核或者严重过时的开放ssl。
当你解决了更新问题在更新过程出现问题时机器人怎么恢复我的示例是对前面问题的一个常见解决方案自动安全更新。对于服务器和台式机以及显然是计算机的东西来说这是一个很好的做法因为大多数人意识到有一个可以接受的方法来关闭它而不是按住电源按钮5秒钟。机器人系统以及大多数物联网系统有一个问题有时它们根本不被认为是计算机。如果您的机器人表现奇怪有可能会被强制关闭。如果你的机器人行为奇怪因为它正在快速安装一个内核更新那么现在你有一个部分安装内核的机器人。你需要有能力处理这种情况。
最后你的工厂流程是什么你如何安装LinuxROS或者你使用的中间件以及你要安装在设备上的你自己的东西小的工厂可能会手工操作但这种方法没有伸缩性容易出错。其他厂商可能会制作一个定制化的初始发行版ISO但这是不小的任务在更新软件时也不容易维护。还有一些厂商会使用专家或者有陡峭学习曲线的自动化工具不久就会意识到你把大量的工程精力投入到本来应该很简单的工作中。
所有这些问题都很重要。针对这些问题,如果你发现自己没有任何明确的答案,你应该加入我们的网络研讨会,在研讨会上我们讨论如何使用开放源代码构建一个商业化机器人。我们会帮助你思考这些问题,并可以回答你更多问题。
作者简介:
Kyle是Snapcraft团队的一员也是Canonical公司的常驻机器人专家他专注于snaps和snap开发实践以及snaps和Ubuntu Core的机器人技术实现。
via: https://insights.ubuntu.com/2017/07/18/things-to-consider-when-building-a-robot-with-open-source/
作者Kyle Fazzari 译者SunWave 校对校对者ID
本文由 LCTT 原创编译Linux中国 荣誉推出