IoT发展

据预测,到2020年物联网设备数量将达到26 billions, M2M的连接将会增长到3.3 billions, 涉及广泛的应用领域。目前,大多数IoT的解决方案依赖于中性化的C-S结构,接入云端。过去数年,IoT从封闭的中心化大型机架构演进到开放式的云中心化结构,而下一步趋势,是将云功能分布到多重节点中。下图展示了IoT架构的进化方向。

Blockchain对于IoT的意义

Blockchain技术最初是用于在没有可信第三方的参与下,防止double-spend的金融问题。经过发展,现在的区块链技术具有图灵完备性,可运行智能合约,与物联网系统某些方面天然地契合,例如在多实体的IoT系统中,可以使用加密货币回避设备实体之间互相信任的必要。基于区块链技术,可以在大规模IoT系统中解决以下挑战:

  1. 成本。很多解决方案由于需要部署和维护中心云、服务器机房,因此花费昂贵,供应商不提供服务器,则成本转嫁到中间商。
  2. 升级维护问题。对成百上千万的智能设备升级软件将是一个挑战。
  3. 安全问题。斯诺登事件之后,IoT集成商难以信任其他的科技合伙公司,用户数据可能被用于收集和分析。因此在未来,隐私和安全将是物联网解决方案的核心考虑。
  4. 闭源的代码造成信任缺失。透明性有助于增加可信度和安全性。因为代码受大众的审视,很容易最早发现漏洞并修补。

区块链技术的分类

按照Public (permissionless) / Private (permissioned), Tocken-Based /  Tocken-Agnostic, 可以将区块链分为4个象限。除了第三象限(公开、无代币)的类型,每一类又可以分为基于逻辑(智能合约)和基于交易Transaction的区块链。最有名的Bitcoin和Ethereum位于第二象限,而Fabric位于第四象限。

是否在IoT中使用BC的评估:

区块链技术并不是普适的,也并不是每个物联网应用必需的。很多情况下,使用传统的数据库,或者有向无环图账本(DAG)就可以满足需求(IOTA,https://www.iota.org/)。仅当一个IoT应用同时具有以下属性时,区块链技术才适用:

  1. Decentralized. 物联网应用需要去中心化,没有可信的中心化系统。当系统中的用户仍旧愿意将信任寄托于某个公司,银行,或者政府机构时,区块链就不是必需的。
  2. P2P exchanges. IoT设备之间存在对等的通信,而不是使用服务器-客户端模型进行通信。否则BC也不适用。
  3. Payment system. 物联网系统中存在金融交易。并且如果实体信任银行或者中间人,金融交易依旧可以使用传统的第三方支付完成。
  4. Public sequential transaction logging. 很多IoT网络收集数据,打上时间戳之后要求序列存储数据。如果具有安全保证,或者鲜有攻击,依旧可以使用传统数据库实现。
  5. Robust distributed system. 分布式系统不应当作为采用区块链技术的一个充分理由,因为分布式系统同样可以在云计算之上构建,除非这个分布式系统的管理实体缺乏可信性。
  6. Micro–transaction collection. 某些物联网应用中,出于审计需要或者日后的大数据分析,需要将每条交易信息都记录下来,这时候可以使用侧链。当某些情况下,通信代价较高时,可以将一段时间内的交易存储在本地,再一次性上传。

以下流程图描述了是否使用区块链技术的评估过程。

物联网应用举例

溯源。利用RFID标签做有机食品的追踪,生物制药过程的监控。

支付。机器间资源使用的小额支付(以电缆传输数据为例)。

IoT安全。Trust Computer Base可信性的远程验证。

架构形式

  1. 云计算、fog、edge.

  1. IBM ADEPT 是一个强调机器自动验证、自我维护的平台。【S. Panikkar, S. Nair, P. Brody, and V. Pureswaran, ‘‘ADEPT: An IoT practitioner perspective,’’ IBM Inst. Bus. Value, New York, NY, USA, White Paper, 2015, pp. 1–18.】
  2. 该论文中描述了Fog computing和Cloud与Blockchain相结合的架构,并在Intel Edison 单板电脑上用golang进行了验证。【M. Samaniego and R. Deters, ‘‘Blockchain as a service for IoT,’’ in Proc. IEEE Int. Conf. Internet Things (iThings), IEEE Green Comput. Commun. (GreenCom), IEEE Cyber, Phys. Social Comput. (CPSCom), IEEE Smart Data (SmartData), Chengdu, China, Dec. 2016, pp. 433–436.】
  3. 利用K8S/docker构建的边缘计算架构。由两层组成,基于Hyperledger Fabric. 【A. Stanciu, ‘‘Blockchain based distributed control system for edge computing,’’ in Proc. 21st Int. Conf. Control Syst. Comput. Sci., Bucharest, Romania, May 2017, pp. 667–671.】
  4. SDN + Fog + Blockchain. 该文章中提出了利用SDN控制雾节点的系统。云用于处理计算密集的任务,而fog node与Blockchain协作,处理延时敏感的任务,并可以实时监测网络攻击。P. K. Sharma, M.-Y. Chen, and J.-H. Park, ‘‘A software defined fog node based distributed blockchain cloud architecture for IoT,’’ IEEE Access, vol. 6, pp. 115–124, Sep. 2017.

共识机制

比特币采用的是PoW共识机制,粗暴地通过算力证明解决了女巫攻击(Sybil attacks).

其他的一些共识算法包括:

  1. PoS (Proof-of-Stake). 基本想象是认为参与度最高的实体具有更小的攻击可能。而“参与度”的一种评价方法就是持有货币的数量。该算法可以降低为了达成共识而白白消耗的计算力,但缺陷在于,最富有的节点似乎可以掌控整个网络。因此对简单PoS有一些改进,例如把持有货币的年龄考虑到参与度的衡量中。
  2. DPoS(Delegated Proof of Stake). 是对PoS的改进,选举出部分节点最为授权节点,参与区块的生成和验证。这使得同时参与共识的节点数量更少,提高了性能。
  3. TaPos (Transactions as  Proof-of-Stake). 也是一种PoS的变种,所有发生了交易的节点会参与到区块的生成过程。【D. Larimer. Transactions as Proof-of-Stake. Accessed ,https://bravenewcoin.com/assets/Uploads/ TransactionsAsProofOfStake10.pdf】
  4. PoA (Proof-of-Activity ). PoS只考虑持有货币的年龄,即使节点离线,年龄依旧会增长。在PoA中,同时考虑节点的活动Activity和货币持有Ownership.
  5. PBFT. 在异步环境中解决拜占庭将军问题(通信可信,节点不可信). 前提是小于1/3的敌对节点。
  6. Ripple consensus algorithm. 共识判定时在几个可信的节点中使用同步的通信方式,因而可以减少延迟。【D. Schwartz, N. Youngs, and A. Britto, ``The ripple protocol consensus      algorithm,'' Ripple Labs, San Francisco, CA, USA, White Paper, 2014】
  7. SCP(Stellar Consensus Protocol). 类似于PBFT的思想,但使用了联邦拜占庭协议(Federated Byzantine Agreement),不用等待所有将军的同意。【D. Mazieres. The Stellar Consensus Protocol: A Federated Model forInternet-Level Consensus. Accessed: Apr. 10, 2018. [Online]. Available:https://www.stellar.org/papers/stellar-consensus-protocol.pdf】
  8. Sieve. IBM提出, Hyperledger-Fabric中 采用的共识机制。
  9. PoB (Proof-of-Burn). 矿工需要燃烧一些加密货币以表挖矿的决心,背后的思想是,用燃烧货币代替POW中的燃烧计算力,因为货币和算力一样都需要代价。
  10. PoP (Proof-of-Personhood). 使用环签名和集体签名(ring signatures and collective signing),绑定虚拟身份和物理身份。【M. Borge, E. Kokoris-Kogias, P. Jovanovic, L. Gasser, N. Gailly, andB. Ford, ``Proof-of-personhood: Redemocratizing permissionless cryptocurrencies,'' 】

Ref:

[T. M. Fernández-Caramés and P. Fraga-Lamas, “A Review on the Use of Blockchain for the Internet of Things,” IEEE Access, vol. 6, pp. 32979–33001, 2018.]

区块链技术在IoT领域的应用综述相关推荐

  1. BlockChain:《区块链技术在医疗领域应用分析》—中投顾问《2016-2020年区块链技术深度调研及投资前景预测报告》听课笔记

    BlockChain:<区块链技术在医疗领域应用分析>听课笔记 导读      医疗行业接纳区块链技术的时间相对来说比较晚,不过并没错过应用区块链的时机.区块链技术正在改变全球医疗行业,逐 ...

  2. 流量矿石团队成员出席“区块链技术与金融领域创新应用培训会”

    区块链技术与金融创新培训会 今日,流量矿石团队的Podsen等多位创始成员参与了由深圳市福田区投资推广署(金融发展事务署)主办.深圳市互联网金融协会承办.深圳市金融信息服务协会.能链众合.全景网络等单 ...

  3. 苏州持续深化区块链技术在公证领域的应用

    近年来,苏州市抢抓区块链发展"窗口期",持续深化区块链技术在公证领域的应用,为公共法律服务真正从法治层面延伸到社会经济发展各方面提供了新思路. 苏州市司法局局长王侃表示,苏州公证行 ...

  4. 区块链技术在证券领域的应用

    更多区块链技术与应用分类: 区块链应用    区块链开发   经济金融业务 以太坊 | Fabric | BCOS | 密码技术 | 共识算法 | 比特币 | 其他链 通证经济 |  传统金融场景 | ...

  5. 区块链技术医疗卫生领域运用综述————医药供应链(2019年4月份)

    区块链技术医疗卫生领域运用综述----医药供应链 FJTCM区块链技术开发学习小组 时间 :2019/04/24 目录 摘要...................................... ...

  6. 区块链技术在医疗保健领域的应用展望

    近年来,全球医疗保健行业的价值呈指数级增长,2018年达到逾8.45万亿美元.而且,这种增长预计将持续下去,到2022年,该行业有望以8.9%的复合年增长率(CAGR)增长至近11.9万亿美元.尽管其 ...

  7. 区块链技术在金融领域的应用

    随着数字化时代的到来,区块链技术已经成为了金融领域的热门话题.区块链技术可以帮助金融机构更安全.高效地进行交易和结算,提高金融系统的透明度和可信度.本文将介绍区块链技术在金融领域的应用,并探讨其优势和 ...

  8. 揭秘高盛区块链报告:区块链技术在五大领域从理论走向实践 | 附报告下载

    来源:亿欧 概要:目前对区块链潜在作用讨论的焦点在于使用分布式账本建立去中心化市场,并削弱现有中间商的控制权,但区块链的潜力比这种单薄的说法来得更加细致也更加深远. 最近,区块链很火,资本市场沾上&q ...

  9. [区块链]区块链技术在教育领域的应用

    系列第一篇文章主要是从商品流通的角度入手,通过分析消费者在目前供应链中遇到的问题,逐步引申出目前供应链中上下游整个体系中信息系统解决不了的问题,寻找痛点,再结合区块链技术特性来给出解决方案.本文为该系 ...

最新文章

  1. 老板说 10 分钟可改完 Bug,为什么我却干了 3 小时?
  2. anaconda切换盘符以及手动安装包
  3. Python函数式编程——map()、reduce()
  4. 人身三流指什么_电气隔离是什么意思呢?
  5. 【Boost】Boost使用几条简单笔记
  6. 阿里高级技术专家:研发效能的追求永无止境
  7. 私有CA的创建和证书的申请
  8. 51nod1130---斯特林公式
  9. UCF101数据集提取帧+TDN部署(Anaconda+Python3.7+Pytorch)
  10. 【树莓派】设置树莓派开机自动运行python脚本
  11. 景区大数据可视化交互系统-全方位旅游服务平台,打造景区信息数据管理分析平台
  12. 每天学点统计学——指数
  13. [转载 蓝韦巍]类似浩方、VS对战平台系统的实现
  14. 阿里巴巴达摩院发布2019十大科技趋势:数字身份将成为第二张身份证
  15. C/C++ 无法解析的外部符号解决方案
  16. lisp倒入excel数据画图_将excel数据导入CAD画图的方法
  17. DASH推流及播放流程
  18. vs2005 sp1 补丁的安装问题
  19. nginx浅析4-限流(秒杀,高并发)
  20. 如何用计算机做大爆炸模拟,【比特大爆炸电脑版】官方手机模拟器怎么玩

热门文章

  1. 【python @ 小甲鱼网课】 P6列表(1)
  2. 中国大学mooc慕课python答案_中国大学MOOC慕课Python编程基础答案公众号
  3. linux中怎么创建管道文件,linux创建管道命令
  4. easyUI 多表头设置
  5. docker 覆盖 entrypoint_Docker容器技术之Docker file
  6. 设计模式详解(四)--------建造者模式
  7. Retrofit 一次个请求下载多个图片
  8. 注册域名需要资格吗_注册域名要具备哪些条件?准备哪些资料?
  9. 高中计算机竞赛在哪学,信息学奥赛获奖学生,都去哪高就了?
  10. 世界名曲百首(mp3)