




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
物联网里开发者必须关注的技术不管是从商业模式导出的业务模型,还是从技术发展的角度看,文本都倾向于将物联网技术构架看作是互联网技术构架的延展。而与这个观念对立的,是传统嵌入式软件开发的视角。1在互联网技术基础上长出来的物联网构架简单来说,目前的互联网技术构架主流是大前端与后端两个世界:大前端包括Web的JavaScript技术、Android和iOS技术,着眼于解决用户交互;后端包括数据库、服务构架、运维等,着眼于解决存储、业务逻辑、安全与效率等。当然,现在前后端技术争相更新,比如业务逻辑前置化、微服务构架、JavaScript全栈化等新的解决方案也开始模糊前后端的差异。而物联网设备端的引入,着实让这些技术有点难以归类,从业务性质上物联网是另外一种前端或是前端的延伸,比如共享单车应用中,自行车端的应用显然是跟人交互的另一个业务场景,也在为后端源源不断地提供着数据,但是自行车又不像网页或者App完全是在解决可视化UI的事情。而且,现在的设备端开发技术跟前端技术太不像了,由于目前设备端的开发技术都还偏底层,一般来说计算资源如处理能力、本地存储都非常有限,反而像后端一样要考虑资源效率。那么,我们只好为物联网单独命名一个端,不如我们暂时就叫它设备端。图1 整体架构图2新后端2.1MQTT新后端核心问题在于加入了面向设备的接入服务,实际上在这里,除类似视频对讲或是安防监控的多媒体实时通道外,这个接入服务已经基本事实化为MQTT。消息队列遥感传输协议是在TCP/IP协议之上使用的,基于发布/订阅的“轻量级”消息协议,目前为ISO标准(ISO/IEC PRF 20922)。它被设计用于轻量级和低带宽的远程连接,发布/订阅消息传递模式需要消息代理,消息代理负责根据消息的主题向需要的端发布消息。如果需要连接的设备没有超过10万台,使用8GB内存的云主机跑Mosquitto就可以;如果设备量是几十万台,可以考虑Mosquitto做集群负载均衡;如果设备量是大几十万台乃至百万台以上,那你需要专业的团队或专门的投入来维护这件事情,这个细节就不在本文讨论范围了。2.2OTA固件组件在线升级是必须要做的事情,MQTT传大文件不靠谱,所以一般传过去一个带Token的URL,设备端去下载就好,HTTP或者HTTPS都可以。业务比较简单,设备端几十万以内没有什么特别的地方。2.3数据存储与服务Mosquitto作为MQTT的引擎,需要后端按照业务逻辑去调用,这里按照业务需求写好后端逻辑即可。在各种后端语言中调用Mosquitto都非常简单。3设备端设备端是物联网领域最五花八门并且正在发展中的地方。其他领域,后端或者前端,经过十几年的发展,已经出现每个细节的主流技术,基本没有碎片化的情况,但是在设备端,开发技术的碎片化是应用发展还不到位的充分表现。举例讲,选用不同的芯片,就要用不同的操作系统,不同的C库封装,各家IDE也不尽相同,编译工具链更是从芯片原厂给出。开发起来呢,寄存器、内存分配、硬件中断都要深入进去。这就是传统嵌入式开发的现状,也是物联网设备端开发的现状。到目前为止,真正生产环境中用到的语言就是C/C+,极个别会在设备端用到Python,基本没有其他语言。操作系统超过50种,主流的也有10种以上,其中嵌入式Linux份额并不大,各种实时操作系统各具特色,各有一片天地。简单总结一下相对于物联网开发,传统嵌入式开发的方式主要有以下几个问题:1. 需要考虑中断、寄存器、内存分配等过于底层的工作;2. 编译、烧写、观察、借助调试设备进行调试的开发生命周期;3. 不同SoC和系统的差异过大;4. 缺乏代码复用与开源的习惯;5. 开发者在开发环境和固件编译上花费的时间过多。所以我们看到设备端的开发是基于芯片选型完成的。当设备端产品面临一个需求时,现有的流程是判断产品的各项技术参数,从而确定一个芯片,进而使用这个芯片的一整套开发技术。这也是早期嵌入式场景使用的芯片自生技术特性所决定:计算资源(CPU主频、存储)、外围接口、使用温度、通讯协议等核心参数的不同导致芯片碎片化,芯片碎片化导致嵌入式开发碎片化。目前这个领域的大趋势是:物联网芯片有望走向趋同,物联网开发环境与技术有望趋同。3.1物联网芯片早期由于成本所限,物联网领域使用的芯片总是表现得非常缺资源,很难找到一个各方面(计算资源、外围接口、使用温度、通讯协议等)都比较合适的芯片去适应普遍的场景。随着半导体门槛逐步降低,中国半导体制造业逐步成型,芯片资源开始走向富余,其中的代表芯片是MTK的MT7697、MT7688和乐鑫的ESP32。MT7697主要参数为:ARM Cortex M4 CPU,带浮点单元,最大主频192Mhz,内存为256KB SRAM,可配置4MB以上的存储空间,芯片内嵌WiFi和BLE 4.2,有足够的外围接口,并能够适应工业级的使用温度。MT7688主要参数为:MIPS 580Mhz CPU,内存最大支持256MB,可配置16GB级别的存储空间,芯片内嵌WiFi,接口除模拟接口之外数字接口丰富,价格在几十元人民币,功耗较高不适于电池长期使用。但是非常有优势的是其提供的Linux开发环境,能够让开发者有一种在普通x86机器上使用linux CLI的体验,Node.js、MySQL、OpenCV、Nginx等等在阿里云上怎么用,在这个几十块的物联网小模块上也怎么用。稳定性超强,几年不死机也是正常的。ESP32的主要参数为:Tensilica LX6 CP,主频240 MHz,内存为520KB SRAM,可配置4MB以上的存储空间,芯片内嵌WiFi和蓝牙以及BLE,有足够的外围接口,并能够适应工业级的使用温度。这几颗芯片共同的特征是计算资源和通讯能力以及接口资源相对于传统MCU来说有足够的富余,并保持在同样的价位。因此,在这类芯片上,有足够的资源做抽象化的封装和开发框架实施。我们看到除了这几颗芯片原厂提供的传统嵌入式开发包之外,社区和其他厂商已经在这几颗芯片上加快了新开发技术的实现。3.2开发技术物联网设备端开发技术目前有两个比较大的发展方向,一是统一化的物联网操作系统,二是统一化的物联网开发框架。他们共同的目的是形成“软件定义物联网”,与传统从芯片选型开始的,着陆于原厂SDK中完成应用开发,与需求和产品设计汇合的流程完全相反,希望从需求和产品设计入手,通过公开统一的软件构架完成开发,再根据开发使用到的资源去落地芯片和外围设备。这样做的好处主要在于提高开发效率和形成可以复用的应用代码。操作系统虽然市场上存在的设备端操作系统有数十种之多,但是我们看到活跃的,明显向“软件定义物联网”方向发展的有三家: ZephyrZephyr是Linux基金会于2016年2月发布的物联网操作系统,背后主要的支持力量来自于ARM和Linaro,具有目前嵌入式小型实时操作系统的普遍特征,比如:轻量到KB级的最小系统内存占用,支持多种芯片构架:从ARM Cortex-M、Intel x86、ARC(DSP 内核)、NIOS II(FPGA 软核)到开源的RISC V等,跟Linux一样的模块化内核组织方式,如图2所示。图2 Zephyr物联网操作系统Zephyr目前已经升级到V1.7版本,逐步向一个可以用到生产环境的系统靠拢了。Zephyr最大的特色并不在于其完备性而在于其开发理念完全来自于“软件定义物联网”,并且有很好的资源支持,在未来应该会有自己的位置。 RTthreadRTthread是纯国产的小型操作系统,植根于中国的各种使用场景,10年来已经确立了自己的地位,在很多行业有自己的一席之地,目前社区非常活跃,核心团队以创业公司的形式推进,非常专注。技术上的特征作为一个成熟的系统,没有什么可以吐槽的地方。Zephyr有的技术优势RTT都有,而且RTT在生产环境的装机量较为可观。 华为LiteOS华为是全球范围内物联网技术的根源厂商之一,LiteOS是一个华为内部很多产品都在用的系统,目前也以开源的形式在全力推广。LiteOS最大的优势在于华为很多根源技术将利用LiteOS进行输出,目前最大的例子就是即将全面商用的NB-IoT技术,设备端的开发包将会用LiteOS输出。以上几个系统一致的特点包括小型化、芯片适应范围广、通信协议适配比较广泛等,他们也都是开源的系统,研发或推动力量比较活跃。有可能在物联网领域里的类似Linux地位的主流操作系统会是其中某个,也或许会一直都存在下去但是在技术上越来越趋同。开发框架首先解释一下开发框架,开发框架可以小到是一个细节的工具,也可以大到规定开发的全部边界。最典型的例子是Android,纯粹操作系统意义上,Android是Linux的一个分支,但是从App开发角度,除NDK之外,没有任何与Linux打交道的地方,所以也把Android叫做操作系统。再广泛地看,Android除了面向手机应用的开发框架,还准备了Google play这样的应用分发渠道,这是开发者生态建设。同理,我们看Node.js在后端的种种开发模式,也是将所有后端资源都封装到JavaScript里,开发时可以随时npm install各种包来require,解决了代码复用问题。因此我的观点是,开发框架以及背后的代码复用和开发者生态才是真正的操作系统。目前在物联网领域,正在尝试向生产环境演进的开发框架基本都基于JavaScript,而在小型实时操作系统上使用的JavaScript runtime目前也基本集中到了JerryScript上。JerryScript是三星开发和开源的一个小资源占用的引擎,内存需要64KB,存储需要200KB即可,能够实现完整的事件驱动,符合ECMAScript 5.1。如同前文所说,开发框架或是操作系统在当下需要包括以代码复用为目的的开发者生态,甚至需要包括应用分发,所以我们看到在JerryScript的基础上,有两家做这类工作的团队值得关注: WRTnodeWRTnode是一个北京的开源硬件团队,提供从开发到硬件交付的全流程服务。他们最近开放的node.system和noyun.io即是着眼于实现物联网JavaScript的开发框架和开发者生态。在WRTnode的实现里,设备端的JavaScript开发已经变得像cloud9.io一样全案在线开发,为开发者屏蔽了嵌入式开发的繁琐编译烧写工作。 RuffRuff是位于上海的创业公司,2015年开始一直在
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年外贸业务员面试实战模拟题与商务谈判技巧解析
- 2025年患者合法权益、知情告知同意、医患沟通技巧培训考试试题(附答案)
- 2025年初创公司市场营销策略模拟题集与答案解析
- 2025年初级炼钢工安全知识面试题
- 益阳医学高等专科学校《单片机原理及应用》2024-2025学年第一学期期末试卷
- 华北理工大学冀唐学院《数据挖掘算法》2024-2025学年第一学期期末试卷
- 2025年新媒体运营师入门手册实操技巧与模拟题集
- 2025年考研英语阅读理解模拟题及答案详解
- 南昌应用技术师范学院《数字媒体技术》2024-2025学年第一学期期末试卷
- 2025年高级物业管理服务营销策略模拟题及答案
- 2024-2025年上海中考英语真题及答案解析
- 人教版小学数学2年级下册课时练无答案+单元测试题+期中期末检测卷(含答案)
- 西南大学2022-2023学年本科教学质量报告
- 督灸技术课件
- 护理查房及病例讨论
- 提升教师专业素养与综合能力的培训
- 人力资源顾问服务合同范本正规范本(通用版)
- 电土施表1-6 专业绿色施工、节能减排管理措施和实施记录
- 幼儿园多媒体课件设计与制作第2版(高职学前教育专业)全套教学课件
- 单位消防安全管理应知应会参考题库300题(含答案)
- 读书分享读书交流会《中国民间故事》
评论
0/150
提交评论