草庐IT

边缘计算概述

吾酥 2023-11-29 原文

什么是边缘计算

从云计算出发

云计算将计算资源、数据资源统一在一个能力很强的地方(云中心),让普通用户成为瘦客户。也就是说,用户将数据存储在云端后,对本地存储能力和计算能力的要求降低,节约升级设备的成本

但云计算也有问题,通信成为了瓶颈,例如:

  1. 宽带低于需求:一个波音787每秒中会产生5G数据,但带宽(无论是地面基站、卫星)远远不能跟上这个要求
  2. 数据通信需要时间(实时性):例如,自动驾驶,每秒产生1G数据,如果这1G数据传到云上完成计算,需要通信时间为800ms(10Gbps by 5G),如果车速为60km/h,800ms已经走过了13米
  3. 能耗大:ZigBee计算的耗能单位是uW,而将数据传输出去的耗能单位是mW,相较于数据计算所耗的能量,云端的传输能耗过大
  4. 安全性:担心把照片放到云端会泄露,隐私性和保密性问题

因此提出边缘计算的概念

边缘计算:边缘计算是指用网络边缘结点来处理、分析数据。其中,边缘结点指的就是在数据产生源头和云中心之间任一具有计算资源和网络资源的结点。**直白的说:就是将计算放置在数据源的附近。**下图中左下灰色波浪部分即是用于计算的边缘节点,相较于云计算,它们离本地较近,云计算的通运问题被部分解决。

边缘计算要解决的问题

  1. 解决高可靠、低延迟计算能力的需求,工业中常需要有此需求
  2. 解决数据中心能耗过大问题
  3. 解决大数据处理的压力:物联网产生的数据会指数级增长,网络传递不了,数据中心处理不了
  4. 解决安全性问题:隐私数据没有上传到数据中心,减少安全风险

边缘计算的案例

  1. 购物车
    每一次操作都同步给云端(可能会出现操作数据丢包的情况,这时本地数据和云端数据不再同步,出现混乱) or 同步到边缘节点,一段时间后将边缘节点的信息一次性同步到云端(丢包可能性大大降低,有一点类似数据库的检查点)
  2. 交通
    互联网汽车需要实时性,将数据传输到云端后计算,再将计算结果传回,以此判断前方是否有人是否需要转向是行不通的,必须本地计算数据保证实时性,此时,汽车中的某计算设备就可以当作边缘节点
  3. 医疗
    医院病床平均有20个以上的联网设备,会产生大量的数据。病人的数据(隐私)处理发生在更靠近边缘的地方,而不是发送到云端,能够避免数据被不当访问的风险。

边缘计算有关提法

  1. 雾计算:2011年由思科(Cisco)提出。

    其实雾计算和边缘计算没有本质区别,都是将计算放置在数据源的附近
  2. 移动边缘计算:欧洲电信标准化协会提出移动边缘计算(Mobile Edge Computing,MEC)
    关键概念是部分移动业务的下沉,提高其业务分发、传送能力,进一步减少时延,并有效抑制核心网络内的拥塞产生

边缘计算参考框架

到目前为止,边缘计算还没有一个好的框架,框架仅供参考

边缘计算参考框架 – 制造

边缘计算核心技术挑战

编程(Program)

Windows环境下的exe不能在Linux上运行,不同操作系统的运行环境不一样,x86和ARM在CPU指令集上都不一样,对于边缘计算来说,异构非常常见,如树莓派基于ARM CPU、NVIDIA Jetson Nano基于GPU、iPhone基于iOS、Huawei Mate 20基于Android等等…
同样的功能,在不同的环境下运行的要求不同,若是对每一个异构都重写一遍,代价太高。
核心挑战:如何编写一个应用程序可以将其分布式部署在边缘计算框架中

命名(Naming)

命名(Naming),即定位资源。例如,监控系统需要用到某个摄像头,若是单机操作,可以根据文件路径命名摄像头,例如,open(/dev/camera0)。但边缘计算框架可能会用到非本地摄像头,怎么处理?一个简单的想法是通过IP地址来找到具体节点,IPV4够用吗?IPV6有具体的较为明确的含义吗?如果有很多很多不同地点的摄像头,我们要记下来一堆没有任何规律的IP地址吗?
核心挑战:资源如何命名来使其适合于大规模动态异构环境?

隔离

计算资源隔离:即应用程序间不能相互干扰。
数据的隔离:即不同应用程序应具有不同的访问权限。
边缘计算更复杂,更容易出现错误,却要求更可靠
Docker: 普遍应用的Docker技术可以实现应用在基于0S级虚拟化的隔离环境中运行
docker介绍:https://www.cnblogs.com/idktp/articles/10538872.html

动态环境

和网络一样,边缘计算也会形成一种网络,具有动态性,下一刻可能会有新节点的加入,也会有旧节点的退出。动态环境有三个步骤:服务发现、快速配置以及负载均衡。
服务发现:计算服务请求者如何知道周边的服务。
快速配置:节点移动、设备开关会造成服务的动态注册和撤销,服务通常也需要跟着进行迁移……
负载均衡:数据、需求、服务、网络、计算、能耗等很多因素决定负载均衡

边缘操作系统

  • 机器人操作系统(robot operating system, ROS) 是一套开源的机器人开发及管理工具,提供硬件抽象和驱动、消息通信标准、软件包管理等 一系列工具,被广泛应用于工业机器人、自动驾驶车辆即无人机等边缘计算场景。
  • EdgeOSH是针对智能家居设计的边缘操作系统,其部署于家庭的边缘网关中,通过3层功能抽象连接上层应用和下层智能家居硬件。
  • EdgeOSv是面向网联车场景的边缘操作系统

ROS有可能成为边缘计算场景的典型操作系统

算法执行框架

  • 人工智能计算是需要执行框架的,实际上任何计算都有执行框架,比如桌面运算
  • 数据中心上的TensorFlow:执行模型训练任务,输入是大规模的批量数据集,关注训练时的迭代速度、收敛率和框架的可扩展性等
  • 边缘节点上的TensorFlow:执行预测任务,输人的是实时的小规模数据,关注预测速度、内存占用量和能效

边缘计算典型框架

OpenVDAP(2018,韦恩州立大学)
KubeEdge(华为)

  • Edged:管理Edge上的容器化应用程序。
  • EdgeHub:Edge的通信接口模块。
  • CloudHub:云端的通信接口模块。
  • EventBus:使用MQTT处理内部边缘通信。
  • DeviceTwin:它是处理设备元数据的设备的软件镜像
  • MQTT: Message Queuing Telemetry Transport,是一个基于订阅/发布的IoT连接协议

Azure IoT Edge(2017,微软)
OpenEdge(2018.12,百度)

哈工大《边缘计算与嵌入式智能》笔记

有关边缘计算概述的更多相关文章

  1. ruby-on-rails - 使用一系列等级计算字母等级 - 2

    这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,

  2. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

  3. 阿里云RDS——产品系列概述 - 2

    基础版云数据库RDS的产品系列包括基础版、高可用版、集群版、三节点企业版,本文介绍基础版实例的相关信息。RDS基础版实例也称为单机版实例,只有单个数据库节点,计算与存储分离,性价比超高。说明RDS基础版实例只有一个数据库节点,没有备节点作为热备份,因此当该节点意外宕机或者执行重启实例、变更配置、版本升级等任务时,会出现较长时间的不可用。如果业务对数据库的可用性要求较高,不建议使用基础版实例,可选择其他系列(如高可用版),部分基础版实例也支持升级为高可用版。基础版与高可用版的对比拓扑图如下所示。优势 性能由于不提供备节点,主节点不会因为实时的数据库复制而产生额外的性能开销,因此基础版的性能相对于

  4. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  5. ruby - 使用 Ruby,计算 n x m 数组的每一列中有多少个 true 的简单方法是什么? - 2

    给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in

  6. arrays - 计算数组中的匹配元素 - 2

    给定两个大小相等的数组,如何找到不考虑位置的匹配元素的数量?例如:[0,0,5]和[0,5,5]将返回2的匹配项,因为有一个0和一个5共同;[1,0,0,3]和[0,0,1,4]将返回3的匹配项,因为0有两场,1有一场;[1,2,2,3]和[1,2,3,4]将返回3的匹配项。我尝试了很多想法,但它们都变得相当粗糙和令人费解。我猜想有一些不错的Ruby习惯用法,或者可能是一个正则表达式,可以很好地回答这个解决方案。 最佳答案 您可以使用count完成它:a.count{|e|index=b.index(e)andb.delete_at

  7. ruby-on-rails - 如何计算 Ruby/Rails 中 JSON 对象的数量 - 2

    Ruby中如何“一般地”计算以下格式(有根、无根)的JSON对象的数量?一般来说,我的意思是元素可能不同(例如“标题”被称为其他东西)。没有根:{[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]}根包裹:{"posts":[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]} 最佳答案 首先,withoutroot代码不是有效的json格式。它将没有包

  8. ruby - 如何计算自 Ruby 中给定日期以来的周数? - 2

    目标我正在尝试计算自给定日期以来周的距离,而无需跳过任何步骤。我更喜欢用普通的Ruby来做,但ActiveSupport无疑是一个可以接受的选择。我的代码我写了以下内容,这似乎可行,但对我来说似乎还有很长的路要走。require'date'DAYS_IN_WEEK=7.0defweeks_sincedate_stringdate=Date.parsedate_stringdays=Date.today-dateweeks=days/DAYS_IN_WEEKweeks.round2endweeks_since'2015-06-15'#=>32.57ActiveSupport的#weeks

  9. 最新版人脸识别小程序 图片识别 生成二维码签到 地图上选点进行位置签到 计算签到距离 课程会议活动打卡日常考勤 上课签到打卡考勤口令签到 - 2

    技术选型1,前端小程序原生MINA框架cssJavaScriptWxml2,管理后台云开发Cms内容管理系统web网页3,数据后台小程序云开发云函数云开发数据库(基于MongoDB)云存储4,人脸识别算法基于百度智能云实现人脸识别一,用户端效果图预览老规矩我们先来看效果图,如果效果图符合你的需求,就继续往下看,如果不符合你的需求,可以跳过。1-1,登录注册页可以看到登录页有注册入口,注册页如下我们的注册,需要管理员审核,审核通过后才可以正常登录使用小程序1-2,个人中心页登录成功以后,我们会进入个人中心页我们在个人中心页可以注册人脸,因为我们做人脸识别签到,需要先注册人脸才可以进行人脸比对,进

  10. ruby - 如何计算两个字符串共有的字符数? - 2

    如何计算两个字符串之间的字符交集?例如(假设我们有一个名为String.intersection的方法):"abc".intersection("ab")=2"hello".intersection("hallo")=4好的,男孩女孩们,感谢你们的大量反馈。更多示例:"aaa".intersection("a")=1"foo".intersection("bar")=0"abc".intersection("bc")=2"abc".intersection("ac")=2"abba".intersection("aa")=2一些补充说明:维基百科定义intersection如下:Int

随机推荐