从芯片到云端:Python物联网全栈开发实践
  • 推荐6
  • 收藏18
  • 浏览5.4K

从芯片到云端:Python物联网全栈开发实践

刘凯 (作者)  李云静 (责任编辑)

  • 书  号:978-7-121-31127-7
  • 出版日期:2017-11-05
  • 页  数:720
  • 开  本:16(185*235)
  • 出版状态:上市销售
  • 维护人:张春雨
电子书 ¥89.00
购买电子书
物联网开发重新定义了“全栈开发”的范围。Python作为一门快速发展的语言,已经成为系统集成领域的优选语言之一,其可覆盖从电路逻辑设计到大数据分析的物联网端到端开发。各领域开发者可以利用Python交叉涉足物联网设备、边缘计算、云计算、数据分析的工程设计。
本书尝试让读者建立物联网设计的整体概念,从基础概念开始,到相关技术选型、开源工程、参考设计与经验分享。无论是物联网领域的创业者,还是系统架构师,都可从本书中获得灵感。本书对于嵌入式开发领域的开发者尤具学习价值,利用Python可加快开发迭代速度、降低开发成本,并可以基于嵌入式Python建立完整的物联网软硬件生态。
精准:单一语言+完整工具链+主流云服务+可扩展系统 宏大:设备端+应用端+服务器端+数据端
刘凯,服务于微电子行业二十余载的资深工程师。曾在飞利浦半导体(即NXP恩智浦半导体前身)任资深工程师,从事软、硬件开发与产品设计等工作,有用汇编/C/C++开发嵌入式系统固件、用Perl/Python脚本做开发支持工具、用PHP/Java/Python做设备云和Web应用的丰富经验。现作为独立系统集成开发商,专业从事物联网相关项目设计和咨询服务,主攻嵌入式、RFID、微控制器、物联网、WSN、Linux、Python、开源等领域。
本书讲述如何以Python为主要编程语言,实现“从芯片到云端”的物联网应用系统快速开发和系统扩展。通过阅读本书,读者可以充分体会Python作为一门全栈开发语言,是如何在物联网的设备端、应用端、服务器端和数据端环节中发挥作用的。
编写本书的初衷是为了让准备或者已经从事物联网开发的读者能够通过Python语言缩短相关学习和开发周期;同时与大家分享一些经验教训,希望能够让读者在具体开发中回避各种“坑”。这不仅对开发团队,对于企业甚至投资者决策也是有益的。
大多数物联网相关书籍比较关注物联网系统和服务器端设计,但是物联网与互联网的设计差别在于:物联网系统设计受限于有限的设备计算能力、巨大的连接数量、独特的数据特征。所以完整的物联网系统设计需要考虑的要素比互联网更多,需要掌握的知识面既广且深。如何在短期内实现系统上线,并安全、平滑地实现规模扩展一直是大家思考的问题。开发者可以采用的对策如下:
 减少开发语言和工具种类。
 使用成熟的参考设计和编程框架。
 使用主流的云计算服务和可扩展的系统设计。
 开源硬件、软件设计和并行开发模式。
有许多事情“开弓没有回头箭”。物联网的最大特点是大量的定制需求,而且上下环节的衔接往往存在技术依赖性,某个环节的决定往往会对其他环节的实施带来很大的影响,并可能造成开发团队间的责任推诿。这需要系统设计者事前做许多调研功课。笔者专注于设备域和服务器域,但本书力求带来更宽的视野,包括物联网相关的应用、产品和生态,介绍不同的系统架构和云计算服务,并在不同的技术选项中推荐几种比较适合工程实施和实际需求的主流组合。
在收集资料的过程中,笔者发现Python作为一门通用编程语言,应用范围非常宽泛。相信本书内容中有许多物联网相关的Python应用是出乎大多数人意料的:
 支持SPICE/IBIS仿真与VHDL设计和电路的自动测试。
 可以在许多流行的8/16/32 MCU上运行,包括AVR/PIC/ARM/MIPS。
 支持绝大多数MCU/MPU/CPU的外设和工业总线,而且编程接口非常灵活。
 可以在各种类型的Linux上运行多种Python运行环境,包括CPython、Jython和各类嵌入式Python。
 通过Jython运行于Java Runtime中,与Java类库完美结合,切入企业级应用和大数据分析。
 可以跨平台开发桌面应用和手机应用。
 大量现成的网络安全和分析工具,可帮助开发者定位通信报文错误,或寻找系统安全漏洞。
 提供大量的辅助工具,包括文档、软件工程、虚拟仪器、媒体处理等,为此笔者特地预留了第8章进行罗列。
 物联网网关、服务器架构、数据分析和可视化、虚拟设备、通信协议定制等领域开发效率超高。
从SPICE/VHDL开始,到服务器,Python实现了“从芯片到云端”的全栈开发。笔者希望这些内容和案例能够帮助开发者在启动项目前对开发有全局性的了解,并做出正确选择。
同时,本书的写作过程采用了Python相关工具,也是“全栈开发”实例之一。
 格式:将Python文档中常见的reST/Markdown作为基础书写格式。
 编译:采用Sphinx将reST章节编译成流行的HTML网页、ePub电子书籍。
 转换:采用Pandoc(Haskell)转换成交付给出版社的docx主流文档格式。
读者可以将本书看作单一编程语言的物联网应用小百科,通过书中的简单例子大致了解物联网的开发流程,并可以根据自己的兴趣,在每章的延伸阅读 清单中深入探索、掌握物联网开发技术的具体实现细节。
目标读者群
本书的目标读者群是以下两大类开发者。
 互联网开发团队:熟悉移动端APP的开发、服务器架构和网页前端开发,但对于传统制造业的技术领域,如芯片设计、硬件设计、固件设计、硬件系统集成,以及批量生产和库存管理缺乏足够的了解。
 设备开发团队:主要是传统制造业产业链中的半导体供应商、独立设计公司、设备制造商。他们熟悉硬件设备的设计和流程,但普遍对于互联网应用和物联网架构缺乏足够的了解。
当前的制造业变化趋势是,设计与平台标准化,导致产品同质化竞争严重。这使得传统制造业在市场中逐渐丧失了议价权和话语权,处于被整合的被动地位。这些企业和团队在物联网时代异常焦虑,急需掌握数据接入和数据分析技术,以增加市场份额,并提升市场竞争力和议价权。本书第9章主要讲述物联网服务器后端开发,可以帮助传统制造业了解服务器端和数据端的发展趋势、大致的技术方案构成,并可以利用Python做些简单的设备测试。
除了工业物联网、行业物联网外,消费端智能硬件领域的物联网开发案例非常多,这是市场热点之一。许多创业团队虽然可以自行设计APP,搭建服务器,但是团队往往缺乏设备端制造经验,并仍在各类硬件问题中艰苦跋涉,苦苦摸索。本书在第4章中介绍了成熟的元器件、连接模块和实时操作系统,配合Python快速原型开发能力,让项目可以快速上市之余,还可以为设备添加各种“智能”应用。
此外,许多读者可能希望从全局角度了解物联网应用、各类技术方案甄选标准,以及具体技术细节。本书也尽可能地进行罗列,并就一些常见问题特别加以说明。
总的来说,本书适合对物联网及相关热点,如智能硬件、工业4.0、万物互联的应用与实现技术感兴趣的人群阅读。目标读者群除了互联网从业者、微电子和OEM/ODM制造商、应用系统集成商,还包括学生、教师、创客、极客、Python语言爱好者、产品经理、项目经理,企业高管和创投基金经理等。
最低阅读要求
由于本书是一本技术书籍,因此需要读者具备一定的编程经验和技术热情。如果读者对于Python基本语法有一定的了解那就更棒了。即便没有Python的使用经验,相信Python易学易用的特点也可以让读者很快入门。
此外,由于代码中大部分采用英语注释,因此需要读者具备基本的英语阅读能力。
本书的目的
核心目的
 为应用开发团队提供设备端硬件、固件开发流程和开发工具方面的工程建议,并提供一些可以用于与服务器对接的硬件平台和参考设计。
 为设备开发团队,提供服务器前后端/移动端的系统架构、开发框架、生态平台方面的工程开发建议,提供可以不断升级的可扩展架构和开发路径,以满足产品从原型测试、中试、量产到分布式规模生产系统整个产品生命周期的需求。
其他目的
 分享基于IaaS/PaaS云计算平台的服务器开发经验,包括设备云、应用云和大数据服务。
 分享可快速部署的物联网网关(Gateway)、边缘服务器(Edge Server)原型设计。
 汇集Python在计算机系统中方方面面的应用信息,并持续更新。
 吸引各方合力推动Python在嵌入式虚拟机/网关/服务器/大数据分析方面的开源活动。
本书内容安排
物联网环节长、技术庞杂,涉及的每种技术领域都值得大家仔细钻研学习。可以这么说,许多话题和技术都可以单独出一本书。所以本书力求在有限的篇幅内,突出物联网特征并使用Python落地生根,使之成为快速开发迭代的基础;与此同时提示在Python应用中可能遇到的问题和解决方案,以降低读者的学习成本。
本书以数据的流动方向,即数据的设备端采集、服务器接入、转发、分析到用户端的呈现为主线,并以Python语言从入门到各个技术栈中的应用作为辅线来安排章节。
本书内容编排经过多次斟酌和修改,最终按照以下顺序介绍。
章 节 简 介
第1章 物联网简介 概述物联网的定义、发展趋势以及物联网应用与技术等
第2章 Python语言基础 数据类型、数据结构、内置函数和标准库
第3章 Python语言进阶 多种实现、与其他语言的接口、物联网常见技巧
第4章 嵌入式系统开发 数字逻辑与模拟电路设计、C/C++固件开发以及主流的平台与供应商
第5章 设备连接和编程接口 物联网的多种连接性与编程接口以及Python支持包
第6章 嵌入式Python虚拟机 深嵌入式、嵌入式Linux最小系统以及各类Python虚拟机实现、演示
第7章 Python应用APP 在主流桌面操作系统和移动端中的Python APP开发
第8章 Python开发辅助支持 在物联网开发环节中的原型验证、虚拟设备、数据分析等多个方面的Python开发工具
第9章 物联网服务器端设计 物联网网关、边缘服务器、Web/IoT服务、开发框架和连接选项
第10章 融合应用与数据分析 科学计算、数据统计、数据挖掘和大数据分析平台和工具,以及数据可视化
除了本书内容,笔者还整理了诸多书中提到的Python扩展包和演示代码,并计划依托出版社网站和其他互联网服务进行分发。本书为笔者一个人写就,缺少专家进行校对,本人水平有限,书中难免有疏漏、错误,欢迎读者指正。但笔者精力亦有限,无法一一回复,祈谅。
本书未包括的内容
因为篇幅的限制,也因为物联网的特性,所以本书安排的内容比较繁杂。本书未能针对特定硬件、软件、云服务展开,也没有针对物联网提供完整的开源设计。这些希望读者在书本之外展开。本书出版后会依托各类互联网服务(如GitHub、社交网站和BBS)展开后续的开源设计活动。
软硬件环境
除非特殊应用和声明,本文主要的操作环境为Windows 7(64位)及Ubuntu Linux 12.04(32/64位)。Python版本为V2.7.11和V3.5。
在微控制器方面笔者推荐ARM mbed兼容的LPC/STM/KL开发板,或Arduino;对于卡片电脑,推荐树莓派或者兼容的国产Linux SBC;对于MicroPython,推荐在STM32F4XX/ESP8266开发板上运行。
版权声明
本书所附代码和硬件,凡是笔者所做,皆采用LGPL协议,读者可以自由用于任意目的;其余软件和硬件,请参考各自官网中的版权声明。本书引用的图片、代码、图表等,其版权皆归属于所属公司、网站和个人。本书引用这些资源主要用于说明目的,且尽量在每章延伸阅读中标明出处。如有遗漏,请联络笔者本人。
感谢
本书付梓需要感谢许多机构和个人。
 知乎网站:本书的创作主题来源于笔者在知乎上的提问,并得到了知乎网友(包括出版社编辑)的热心解答、正面鼓励和推动才能够走到这一步。
 张春雨先生(永恒的侠少),电子工业出版社的策划编辑:在知乎上遇见后,你一路推动本书的出版。感谢你的耐心和鼓励。
 张成先生,物联网创业伙伴:张成先生,物联网创业伙伴:不断鼓励笔者继续深入物联网开发,并拨冗为本书作序。
 EEWorld编辑nmg和版主dcexpert:他们提供了宝贵的MicroPython pyboard开发板。
 诸多开源项目的作者们:感谢大家对于开源软硬件项目的热情和不厌其烦解答问题的耐心。
芯片供应商及分销商:
 NXP(恩智浦),感谢免费提供LPC系列开发板。
 Freescale(飞思卡尔,已与NXP合并),感谢慷慨提供大量KL25的样片及技术支持。
 TI(德州仪器)及分销商Serial(新晔科技),感谢提供WSN技术支持。
 Cypress,感谢免费提供PSoC开发板。
 Fujitsu(富士通),感谢友情提供FeRAM RFID。
 Atmel(爱特梅尔),感谢免费提供MCU、Wi-Fi和Crypto产品开发板。
 Nuvoton(新唐科技),感谢免费提供MCU开发板。
最后感谢自己的父母和妻子,忍受笔者在放弃其他工程开发的情况下编写本书。
轻吻女儿Kirin,谢谢你的耐心等候。

刘凯(奕辰,Allan K Liu)
2017夏,上海

目录

第1章 物联网简介 1
1.1 物联网定义 1
1.2 物联网发展趋势 1
1.3 物联网应用与技术 2
1.3.1 物联网核心价值 2
1.3.2 物联网发展阶段 3
1.3.3 物联网分层 5
1.3.4 物联网数据传输与网络拓扑 5
1.3.5 物联网实施所需技术栈 8
1.3.6 标准、现状与未来 10
1.4 本章小结 16
第2章 Python语言基础 17
2.1 Python的由来与特征 19
2.1.1 概述 19
2.1.2 设计定位与哲学 19
2.1.3 优点与缺点 20
2.2 Python与物联网开发 22
2.3 获取Python资源 24
2.3.1 Python主程序 24
2.3.2 Python文档 24
2.3.3 Python PyPI 24
2.4 Python解释器运行环境 26
2.4.1 REPL交互模式 26
2.4.2 直接运行与模块运行 26
2.4.3 脚本文件直接运行 27
2.4.4 源程序文字编码与结束符 28
2.5 Python类型与语法 29
2.5.1 动态类型 29
2.5.2 传值与传引用 30
2.5.3 数据类型 31
2.5.4 内置类型 32
2.5.5 内置类型的普适操作 34
2.5.6 数值类型 35
2.5.7 布尔类型 37
2.5.8 迭代器类型 37
2.5.9 生成器类型 38
2.5.10 yield表达式 39
2.5.11 序列类型 39
2.5.12 set集合类型 54
2.5.13 映射类型 55
2.5.14 其他类型 56
2.5.15 控制流 59
2.5.16 内置函数 61
2.5.17 用户自定义函数 62
2.5.18 模块 65
2.5.19 输入/输出 68
2.5.20 面向对象编程 74
2.5.21 进程和线程 82
2.5.22 错误和异常 90
2.6 Python标准库概览 93
2.7 本章小结 94
第3章 Python语言进阶 95
3.1 HOWTO:常见任务和解决方案 95
3.1.1 数据类型转换 96
3.1.2 数据的调试打印 100
3.1.3 数据类型资源优化 102
3.1.4 数据结构与算法 102
3.1.5 数据缓存 103
3.1.6 数据多路复用和解复用 104
3.1.7 数据序列化和反序列化 107
3.1.8 数据压缩和解压缩 119
3.1.9 数据加密 120
3.1.10 数据传输 121
3.1.11 数据后处理 121
3.1.12 数据持久化 121
3.1.13 数据交换 122
3.2 HOWTO:函数式编程 123
3.2.1 高阶函数 123
3.2.2 map函数 124
3.2.3 reduce函数 124
3.2.4 filter函数 124
3.2.5 sorted函数 125
3.2.6 返回函数 125
3.2.7 闭包 126
3.2.8 匿名函数 126
3.2.9 装饰器 127
3.3 HOWTO:并发运行模型 131
3.3.1 协程 131
3.3.2 I/O模型 134
3.4 HOWTO:日期与时间 136
3.4.1 类型转换 136
3.4.2 时区的处理 138
3.5 Python版本迁移 139
3.5.1 Python 2与Python 3的区别 140
3.5.2 Python 2到Python 3的流程 140
3.5.3 多个Python版本共存 140
3.5.4 virtualenv 141
3.5.5 Windows多个版本共存 141
3.5.6 Linux多个版本共存 142
3.6 其他常见技巧 143
3.6.1 常数类型的模拟 143
3.6.2 枚举类型的模拟 143
3.6.3 开发自定义模块 144
3.7 Python与其他语言 145
3.8 Python语言扩展 151
3.8.1 C语言扩展Python 151
3.8.2 ctypes访问Windows DLL 153
3.8.3 Jython访问Java类 154
3.8.4 IronPython访问.NET 155
3.9 Python加速 157
3.9.1 PyPy 158
3.9.2 Cython 159
3.9.3 PyCUDA 159
3.9.4 PyOpenCL 159
3.9.5 Theano 159
3.9.6 Nuitka 159
3.10 本章小结 160
第4章 嵌入式系统开发 161
4.1 嵌入式系统硬件分类 162
4.1.1 MCU 162
4.1.2 MPU 163
4.1.3 DSP 163
4.1.4 SMP 164
4.1.5 异构大小核 164
4.1.6 FPGA原型 165
4.1.7 SoPC 165
4.1.8 GPU 167
4.1.9 哈佛结构和冯•诺依曼结构 168
4.2 电路原型设计 168
4.2.1 集成电路设计流程 170
4.2.2 模拟电路原型设计 170
4.2.3 数字电路原型设计 175
4.3 常见嵌入式微控制器(MCU) 179
4.3.1 MCU市场状况 179
4.3.2 Arduino/Wiring 180
4.3.3 ARM mbed 181
4.3.4 设计专属架构和专属MCU 182
4.3.5 ARM MCU差异化竞争 182
4.4 常见嵌入式处理器和主板 184
4.4.1 ARM架构 185
4.4.2 其余的ARM Linux主板 188
4.4.3 MIPS开发板 190
4.4.4 x86 mini-ITX 191
4.5 常见传感器和执行器 192
4.5.1 虚拟传感器 193
4.5.2 智能传感器 193
4.5.3 专用传感器 194
4.5.4 执行器 195
4.6 物联网通信集成电路 196
4.7 嵌入式系统开发语言演进 197
4.7.1 从汇编到嵌入式C 197
4.7.2 从C到C++ 199
4.7.3 压缩C++的系统消耗 199
4.7.4 C++适合物联网开发 200
4.8 C/C++的编程模式和技巧 204
4.8.1 C/C++设计模式 205
4.8.2 回调函数 206
4.8.3 有限状态机模型 209
4.8.4 善用结构体 211
4.8.5 C/C++协程 214
4.9 开发生态选择 215
4.9.1 工业标准与厂家私有指令集架构 215
4.9.2 硬件与软件平台选择 215
4.9.3 编译器选择 216
4.10 常见操作系统 217
4.10.1 无操作系统 217
4.10.2 RTOS的优势 218
4.10.3 uC/OS 219
4.10.4 Keil RTX 219
4.10.5 mbed RTOS与mbed OS 220
4.10.6 FreeRTOS 221
4.10.7 Linux是开发复杂联网设备的现实选择 222
4.11 物联网中间件 227
4.11.1 WSN堆栈 227
4.11.2 TCP/IP 227
4.11.3 USB 227
4.11.4 FAT/FS 228
4.11.5 GUI 228
4.11.6 Terminal 228
4.11.7 MQTT 228
4.11.8 CoAP 229
4.12 物联网安全性 230
4.12.1 安全相关芯片 230
4.12.2 安全中间件 231
4.12.3 Python安全算法 232
4.13 设备固件更新 232
4.13.1 固件更新技术发展史 232
4.13.2 本地固件更新 234
4.13.3 远程固件更新 234
4.13.4 固件升级定制 234
4.14 各类串口实现联网 235
4.14.1 串口协议的选择 235
4.14.2 模拟串口设备 236
4.14.3 其他类型虚拟设备 238
4.14.4 ISP编程器 238
4.14.5 串口设备监控器 239
4.15 本章小结 239
第5章 设备连接和编程接口 240
5.1 设备连接概述 240
5.1.1 嵌入式系统连接层次 240
5.1.2 选择正确的连接方案 241
5.1.3 具体落实连接设计 241
5.1.4 本章内容安排 242
5.2 连接能力汇总 242
5.2.1 连接由芯片开始 243
5.2.2 芯片内部系统总线 245
5.2.3 芯片间连接技术 246
5.2.4 设备间连接 249
5.2.5 设备组网 250
5.2.6 设备组网与联网的无线技术 253
5.2.7 连接性回顾 266
5.3 Linux文件系统 266
5.3.1 设备即文件 266
5.3.2 设备文件系统 267
5.3.3 Linux设备文件的演变 268
5.3.4 文件I/O操作 271
5.3.5 Linux硬件编程 272
5.4 并行接口 273
5.4.1 老旧的PC并行接口 274
5.4.2 高速总线 274
5.4.3 GPIO 274
5.4.4 Linux访问GPIO 275
5.4.5 GPIO的Python包 276
5.5 串行接口 277
5.5.1 异步通信串行口 277
5.5.2 I2C总线 284
5.5.3 SPI总线 290
5.5.4 与其他硬件平台相关的Python包 294
5.6 USB总线 296
5.6.1 USB Endpoints 297
5.6.2 USB Device/Host/OTG 297
5.6.3 USB 3.0 297
5.6.4 libUSB 297
5.6.5 PyUSB 298
5.6.6 标准化USB桥接 299
5.6.7 与USB相关的其他设计 301
5.7 Linux网络设备驱动 301
5.7.1 TCP/IP套接字编程 301
5.7.2 IEEE 802.3到IEEE 802.11 302
5.7.3 网络通信实现方案 302
5.7.4 私有通信协议栈 305
5.7.5 短距离无线连接 307
5.8 工业总线 310
5.8.1 CAN总线 310
5.8.2 LIN总线 312
5.8.3 其他ASIC 313
5.8.4 定制Python扩展 313
5.8.5 Windows DLL 314
5.9 本章小结 314
第6章 嵌入式Python虚拟机 315
6.1 嵌入式高级语言平台大荟萃 315
6.1.1 高级语言与二次开发 315
6.1.2 BASIC 319
6.1.3 Java 319
6.1.4 Lua 322
6.1.5 JavaScript 322
6.1.6 .NET 323
6.2 前一代Python虚拟机 323
6.2.1 Telit GPRS模块 323
6.2.2 Symbian 325
6.2.3 Windows CE 325
6.2.4 OpenMoko 325
6.3 深嵌入式Python平台 326
6.3.1 LEGO EV3 326
6.3.2 TinyPy 326
6.3.3 嵌入式Python的局限 327
6.4 PyMite 328
6.4.1 硬件平台 328
6.4.2 维护者 329
6.4.3 pymbed分支 329
6.4.4 开发现状 331
6.4.5 文档 332
6.4.6 源码树 333
6.4.7 使用流程 335
6.4.8 实践 336
6.4.9 工程小结 337
6.4.10 网络资源 338
6.5 VIPER/Zerynth 338
6.5.1 硬件平台 339
6.5.2 Zerynth Studio 340
6.5.3 与标准Python的区别 341
6.5.4 快速启动 342
6.5.5 坎坷的使用过程 342
6.5.6 Zerynth目录结构 343
6.5.7 硬件相关库 344
6.5.8 其他特性 355
6.6 MicroPython 356
6.6.1 工程背景知识 356
6.6.2 在线评估网页 358
6.6.3 官方硬件平台分支 358
6.6.4 衍生项目 359
6.6.5 UNIX版本 360
6.6.6 MicroPython库 363
6.6.7 STM32HAL分支 365
6.6.8 NUCLEO-F401RE适配 367
6.6.9 pyboard评估 372
6.6.10 异步处理和中断处理 389
6.6.11 中断处理的普遍问题 392
6.6.12 使用心得 395
6.6.13 商品化与知识产权 396
6.6.14 BBC microbit 396
6.7 Linux与Python 398
6.7.1 Linux中Python的运行环境 398
6.7.2 交叉编译CPython 401
6.7.3 交叉编译MicroPython 402
6.7.4 Jython运行环境 404
6.7.5 Android SL4A 406
6.8 本章小结 407
第7章 Python应用APP 408
7.1 基于字符的人机界面 409
7.1.1 命令行参数 409
7.1.2 字符终端开发 410
7.1.3 ncurses 411
7.2 桌面GUI开发 412
7.2.1 Tkinter 413
7.2.2 wxPython 414
7.2.3 Boa Constructor 415
7.2.4 wxGlade 416
7.2.5 PyGTK 417
7.2.6 PyQt 419
7.2.7 PySide 420
7.2.8 Enthought 421
7.2.9 Cocoa+PyObjC 423
7.2.10 Java AWT 424
7.2.11 IronPython与WPF 425
7.2.12 其他UI 425
7.3 本地Web GUI 426
7.3.1 与WebKit相关的Python包 427
7.3.2 OneRing 427
7.3.3 Pyjs 427
7.3.4 Python Flexx 428
7.4 本地可执行文件 429
7.4.1 Linux可执行文件 429
7.4.2 Mac OS X应用程序包 430
7.4.3 Windows可执行文件 430
7.4.4 pyinstaller 430
7.4.5 py2exe 430
7.4.6 py2app 430
7.4.7 cx_Freeze 431
7.4.8 Windows系统服务 431
7.4.9 Windows定时任务 432
7.4.10 Linux系统服务 433
7.4.11 Linux定时任务 435
7.5 移动APP开发 436
7.5.1 响应式网页 437
7.5.2 PhoneGAP应用开发 437
7.5.3 SL4A 437
7.5.4 QPython开发 441
7.5.5 Kivy 443
7.5.6 其他开发方式 449
7.6 本章小结 449
第8章 Python开发辅助支持 451
8.1 物联网开发需要不断优化 452
8.2 专属小工具 452
8.2.1 单位转化器 453
8.2.2 内码转换器 454
8.2.3 其他编码转换 455
8.3 原型验证 458
8.4 代码生成器 459
8.5 软件测试 461
8.5.1 unittest单元测试 462
8.5.2 socket压力测试 462
8.5.3 urllib2远程记录 463
8.5.4 PCBA测试 466
8.6 文档生成器 468
8.6.1 文档格式 469
8.6.2 文档生成工具 473
8.7 文档操纵 477
8.7.1 Doc文档操纵 477
8.7.2 Excel表格操纵 478
8.8 国际化与本地化 479
8.8.1 gettext 479
8.8.2 Web多语种切换 482
8.8.3 字库文件生成器 482
8.8.4 GB2312点阵字库提取 482
8.8.5 TTF字库提取 483
8.9 配置管理 484
8.9.1 软件配置管理 484
8.9.2 软件配置管理自动化 485
8.9.3 Git Bash 485
8.9.4 Dulwich/Gittle包 485
8.9.5 Python Subversion包 486
8.9.6 watchdog系统监控 486
8.10 数据与素材处理 486
8.10.1 二维码显示 486
8.10.2 多媒体相关软件包 490
8.10.3 地理位置 494
8.11 通信报文分析 495
8.11.1 PyShark 495
8.11.2 pypcapfile 497
8.11.3 scapy和scapy3k 497
8.11.4 pcap Web分析 497
8.12 与Arduino/mbed相关的Python包 497
8.12.1 Arduino Prototyping 498
8.12.2 pyFirmata 501
8.12.3 Py2B 501
8.12.4 CmdMessager 501
8.12.5 mbed 504
8.12.6 mbed RPC 504
8.12.7 mbed-ls 505
8.12.8 Python-mbedtls 507
8.12.9 Python-xbee 508
8.13 虚拟仪器 509
8.13.1 实时显示波形 510
8.13.2 Instrumentino 510
8.13.3 Vipy 511
8.13.4 PyVISA 511
8.13.5 Pythics 512
8.14 3D/VR/AR 512
8.14.1 PyOpenGL 513
8.14.2 PySoy 514
8.14.3 VPython 514
8.14.4 Printrun 3D打印 514
8.15 本章小结 515
第9章 物联网服务器端设计 516
9.1 物联网计算模型 517
9.1.1 云计算 517
9.1.2 Web PaaS与IoT PaaS 518
9.1.3 IoT PaaS供应商 518
9.1.4 PaaS/IaaS混合架构 524
9.1.5 雾计算 525
9.2 物联网与互联网设计异同 526
9.2.1 基础架构 526
9.2.2 标准化程度 527
9.2.3 业务模式 527
9.2.4 系统构成 527
9.2.5 设备接入协议 528
9.2.6 数据特性 529
9.2.7 系统架构 530
9.2.8 数据持久层 532
9.2.9 大数据分析架构 534
9.2.10 业务耦合与分离 534
9.2.11 业务与数据融合 535
9.2.12 认证授权与计费 535
9.3 物联网网关与边缘服务器 535
9.3.1 Python socket服务器 536
9.3.2 pyserial RFC2217 536
9.3.3 SubGHz网关panStamp 537
9.3.4 Rascal micro 538
9.3.5 Java IoT网关 539
9.4 物联网设备接入协议 540
9.4.1 异步通信框架Twisted 541
9.4.2 Twisted 套接字服务器设计 544
9.4.3 物联网专用协议 558
9.4.4 CoAP 560
9.4.5 MQTT 564
9.4.6 mosquitto/paho 567
9.4.7 REST API 572
9.4.8 服务器数据推送技术 572
9.5 高可用性与高并发性 575
9.5.1 并行与并发计算 575
9.5.2 网络I/O模型分类 575
9.5.3 架构优化的路径 576
9.5.4 关系数据库系统 576
9.5.5 SQL/NoSQL/NewSQL 578
9.5.6 Redis 579
9.5.7 MongoDB 580
9.5.8 时序数据库 581
9.5.9 消息队列 583
9.6 业务与数据融合 585
9.6.1 网站权限管理 585
9.6.2 认证授权与计费 586
9.6.3 OpenID 587
9.6.4 OAUTH 587
9.6.5 OpenID与OAUTH的异同 588
9.6.6 社交化硬件 588
9.7 Web开发框架 589
9.7.1 MVC模型 589
9.7.2 Web开发流程 589
9.7.3 Python Web百花齐放 590
9.7.4 Zope 591
9.7.5 Django 591
9.7.6 Flask 592
9.7.7 gevent提升性能 593
9.7.8 异步Web框架Tornado 593
9.7.9 异步网络框架Twisted 593
9.7.10 异步Web框架Cyclone 594
9.7.11 静态网页 594
9.7.12 TLS安全网页 594
9.8 物联网安全 597
9.8.1 物联网安全现状堪忧 598
9.8.2 操作系统安全 598
9.8.3 数据缓存与数据持久层安全 599
9.8.4 Web框架与容器安全 599
9.8.5 远程加载风险 600
9.8.6 Web前端安全 600
9.8.7 传输层安全 601
9.9 服务器交付 603
9.9.1 虚拟机交付 603
9.9.2 Docker容器交付 603
9.9.3 VirtualEnv交付 605
9.10 服务器运维 605
9.10.1 Linux定时任务 606
9.10.2 常见的定时任务 610
9.10.3 系统监控 611
9.10.4 集成化运维软件 613
9.11 物联网系统设计实践 614
9.11.1 服务器端需求分析 614
9.11.2 确定设备接入方式 616
9.11.3 物联网的实时要求 617
9.11.4 EPIC IoT设备服务器 617
9.11.5 EPIC架构优化 619
9.12 本章小结 625
第10章 融合应用与数据分析 626
10.1 物联网是可编程的 626
10.1.1 Web API的“满汉全席” 627
10.1.2 Web API技术演进 628
10.1.3 IoT Web API的必要性 628
10.1.4 Device as a Service 629
10.2 数据统计、分析和挖掘 630
10.2.1 名词解释 630
10.2.2 术语小结 631
10.2.3 大数据分析 632
10.3 采集整理自有数据 633
10.3.1 原始设备数据 633
10.3.2 数据埋点 633
10.3.3 服务器端数据 634
10.3.4 需求确定分析方法 637
10.4 采集第三方数据 637
10.4.1 结构化数据 638
10.4.2 半结构化数据 638
10.4.3 非结构化数据 639
10.4.4 数据录入 644
10.4.5 数据融合 644
10.4.6 数据规整 646
10.4.7 数据交易 646
10.5 数据分析 647
10.5.1 常见编程语言 647
10.5.2 数据分析分类 647
10.5.3 科学计算数据分析工具 651
10.5.4 统计学数据分析工具 658
10.5.5 金融数据分析工具 659
10.5.6 大数据平台与生态 661
10.6 数据可视化 663
10.6.1 数据可视化的发展趋势 664
10.6.2 matplotlib 665
10.6.3 seaborn 665
10.6.4 mpld3 666
10.6.5 Chaco 667
10.6.6 Pygal 668
10.6.7 Plotly 670
10.6.8 TVTK 671
10.6.9 VPython 672
10.6.10 Folium 673
10.6.11 NetworkX 674
10.6.12 Bokeh 676
10.6.13 Mayavi 678
10.6.14 Vispy 680
10.6.15 MoviePy 681
10.6.16 其他新技术 682
10.7 本章小结 682
推荐书目与结束语 683

本书勘误

印次
  • 页码:6  •  行数:17  •  印次: 3

    “Bluetooth 5.0之后增加的Mesh”中,“Bluetooth 5.0”应为“BLE4.0”

    beyond 提交于 2019/2/22 23:09:21
    张春雨 确认于 2019/4/22 13:46:55
  • 页码:532  •  行数:14  •  印次: 1

    9.2.8 数据持久层
    ……基于海量数据并在可接收的时间(如0.1秒)内进行数据的插入……
    这里的「接收」应该为「接受」。

    pl01665077 提交于 2018/2/25 11:47:25
    张春雨 确认于 2018/8/22 9:12:51

读者评论

  • 一翻看就看到一个错误呀,P6,”Bluetooth 5.0之后增加的Mesh…”,Mesh并不是ble 5.0才提出来的

    beyond发表于 2019/2/22 23:08:29

电子书版本

  • Epub

相关博文

相关图书

亿级流量系统架构设计与实战

李琛轩 (作者)

本书涵盖了亿级用户应用后台通用的技术和系统架构设计思路,在内容结构上分为三大篇:架构知识篇(第1~3章),作为全书的基础知识篇,首先介绍后台的关键组件构成以及机...

 

B站运营大揭秘:百万Up主真想教会你的创作笔记

本书由B站的三位百万级Up主(GenJi是真想教会你、鱼C-小甲鱼、阿Test正经比比)联合打造,为读者提供了B站独家运营秘籍。 全书总计8章。第1章重点讲解...

 

手机摄影从实战到精通

追风 (作者)

这是一本非常好用的手机摄影指南,旨在帮助读者全面掌握手机摄影从实战到精通的方方面面,使读者通过手机能轻松地拍摄出高质量的视频。 全书总计7章。 第1章讲解对...

 

AI魔法绘画:用Stable Diffusion挑战无限可能

陈然 (作者)

本书以实际操作为导向,详细讲解基于Stable Diffusion进行AI绘画的完整学习路线,包括绘画技巧、图片生成、提示词编写、ControlNet插件、模型...

 

一本书读懂ChatGPT

魏进锋 (作者)

本书以通俗易懂的语言对ChatGPT进行全面讲解。 本书分为10章。 第1章对ChatGPT及ChatGPT的创造者OpenAI进行初步讲解。 第2章讲解...

 

Istio权威指南(上):云原生服务网格Istio原理与实践

张超盟 (作者)

本书是《Istio权威指南》的上册,重点讲解Istio的原理与实践,分为原理篇与实践篇。 原理篇介绍Istio的相关概念、主要架构和工作原理。其中,第1章...