Dapr 助力应用架构的可持续性
在文章亚马逊可持续软件工程实践[1] 有这么一段我们为什么要关注“可持续发展”:
联合国于 2015 年制定了一个全球框架《巴黎协定》[2],随后各缔约国纷纷制定了“碳中和”路径和目标,对地球环境的健康发展做出承诺。今年两会,中国也将“碳中和”和“碳达峰”写入政府工作报告,目标在 2030 年前实现“碳达峰”,2060 年前实现“碳中和”。毋庸置疑,可持续发展已经成为不言而喻的社会共识。但在社会共识之下,还需要个人、企业、政府等各类社会主体的参与——其中体量庞大的科技企业是至关重要的参与者。
在探讨应用程序的碳足迹时,我们通常应该考虑两个角度。运行它使用了多少能量(即内核数量、执行时间、硬件效率等)以及产生多少能量对环境产生了影响,这称为碳强度,取决于位置、时间和数据中心使用的能源类型(天然气、煤炭、风能等)。2016 年的一项研究证明,大约 55% 的消耗能源取决于计算系统,其余 45% 用于支持计算(冷却、UPS 等)。
2020 年标志着 IT 界开始形成全球共识:软件和应用程序具有必须考虑的足迹,并且正在开发算法来评估这些足迹[3]。我最近一直在探索 Dapr 的创新,这是一个为分布式应用程序运行时创建的开源项目,目前是CNCF的孵化项目,项目官网:https://dapr.io/。根据其主页介绍,“Dapr 是一个可移植的、事件驱动的运行时,它使任何开发人员都可以轻松构建在云和边缘上运行的弹性、无状态和有状态的应用程序,并包含语言和开发人员框架的多样性。” Dapr 的主要梦幻般的特性确实是其实现的简单性以及跨任何编程语言、框架和基础架构工作的能力,它促使开发人员在接近他们的软件架构时更容易开始考虑IT可持续性。我们从三个方面来谈谈Dapr 在可持续性方面给开发人员带来的方便。
首先是Dapr 助力应用程序衡量自身的碳排放。在分布式解决方案中,我们通常可以有几种不同的基础设施环境和编程语言。理想情况下,这应该通过一个专用的微服务来完成,该微服务可以持续监控每种能源的碳排放,并且能够为应用程序的其他部分提供这些信息。Dapr 在衡量其基础设施的性能影响方面非常精确,并就如何衡量采用 Dapr 的微服务所使用的性能提供了指导。正如Dapr文档中提到的,有一些方法可以检索 CPU 和内存使用情况,这有助于消除总体碳影响。此外,以递归方式,此微服务还应监控其自身的碳排放。
第二点是Dapr 助力应用程序通过控制其 IaC(基础设施即代码)来驱动/改变其碳排放,碳排放并不是一个固定的数量,并且很大程度上取决于基础设施所在数据中心的能源状况,因此应用程序可以具有自动化,触发全部或部分基础设施向影响较小的站点或区域移动。对于某些地区来说,这可能不是立竿见影的,甚至是不可行的(例如需要考虑数据主权和延迟),但在适用的情况下, 分布式应用程序的高度优化的可持续基础设施,可以保证在影响较小的环境中运行基础设施(出于同样的原因,可能是最便宜的),Dapr 非常容易就可以做到环境的适应性。从目前全球情况来看,亚马逊、谷歌、微软这三家世界级科技巨头引领了“绿色云”改造。亚马逊表示将提前十年达成《巴黎协定》,并在 2025 年实现 100% 可再生能源。并且还成立了 20 亿美元的气候承诺基金,投资那些能帮助亚马逊达成目标的公司。谷歌大胆承诺,到 2030 年实现数据中心全天候无碳运行,而不是依靠每年的直接能源匹配。微软(Microsoft)自 2012 年起实现碳中和,并承诺通过电力购买协议,到 2025 年实现数据中心完全使用可再生能源。而在中国,互联网科技企业也都在不断加大力量投入到碳中和改造中。今年 8 月国际环保组织绿色和平(Greenpeace)发布了中国科技巨头《绿色云端2021》[5]排行榜,从能源信息披露、节能减碳表现、可再生能源方面合梳理了中国互联网科技企业的气候行动,相比去年,中国互联网科技企业整体平均得分上升 11%。
第三点是Dapr 助力应用程序根据用户行为驱动/改变其碳排放影响,应用程序可以根据功能的碳排放提供不同级别的功能,并根据功能的影响级别提供多样化的用户体验,将知情权选择留给最终用户。有更多的空闲时间吗?你为什么不试试这个稍微高一点的延迟水平,通过使用更环保的基础设施来节省 xx% 的碳?你真的需要加载所有高分辨率图片吗?等等。这显然会在编程方面带来一些开销,但其执行的美妙之处在于应用程序将定义并教育最终用户对其影响发表意见,并且在一段时间后通过监控用户所做的选择,您还可以拥有关于他们希望如何与您的软件交互的反馈。随着时间的推移,您将清楚地了解哪种组合可以更好地平衡性能和节能。Dapr 偏爱异步架构模式,尤其是依赖于微服务之间的发布/订阅交互。通过向外扩展和向内扩展来处理请求,可以在对用户需求的动态响应和对我们希望为工作负载提供的资源的控制之间实现最佳折衷。
IT可持续性是我们在设计应用程序时必须开始考虑的工作了,优化工作负载以提高利用率,我们可以分散定时任务,降低负载峰值,达到调整 CPU 使用效率的目的。 重要的是,优化并不是只考虑某一个地方就可以,需要我们在架构和系统层面去思考,每位开发者都可以从现在开始去理解“可持续性”相关的术语和原则,在工作中寻找优化负载的机会。Dapr 在架构和系统层面为我们设计 可持续的应用程序提供了秘密武器。
[1]亚马逊可持续软件工程实践: https://www.infoq.cn/article/9dIy3T8NEmohhPU9QFe2
[2]巴黎协定:https://zh.wikipedia.org/wiki/%E5%B7%B4%E9%BB%8E%E5%8D%94%E5%AE%9A
[3]绿色软件工程原理: https://principles.green/
[4] Dapr : https://dapr.io/
[5]绿色云端 :https://www.eet-china.com/mp/a69760.html
Dapr 助力应用架构的可持续性的更多相关文章
- Dapr中国社区活动之 分布式运行时开发者日 (2022.09.03)
自2019年10月首次发布以来,Dapr(Distributed Application Runtime,分布式应用运行时)因其"更稳定"."更可靠".&quo ...
- 京东云数据库 RDS助力企业便捷运维
iPhone6发布那年,京东在国贸等商圈送货最快速度数分钟,包括从下单到送达.这是一个极端的富含营销因素例子.即便如此,常态来看,隔天到货的这种业务模式,也是基于同样的支撑:营销业务.物流业务,大数据 ...
- Dapr + .NET Core实战(十三)跨语言开发
因为基于Dapr的服务架构是不限语言的,我们来看看Dapr的跨语言开发.我们使用golang,python,.NET来实现跨语言的服务调用,拓扑如下 我们继续使用.NET 5的fontend和back ...
- 【巨杉数据库SequoiaDB】巨杉数据库荣获《金融电子化》“金融科技创新奖”
巨杉助力金融科技创新 2019年12月19日,由<金融电子化>杂志社主办.北京金融科技产业联盟协办的“2019中国金融科技年会暨第十届金融科技及服务优秀创新奖颁奖典礼”在京成功召开.来自金 ...
- Apache ShardingSphere 在京东白条场景的落地之旅
京东白条使用 Apache ShardingSphere 解决了千亿数据存储和扩容的问题,为大促活动奠定了基础. 2014 年初,"京东白条"作为业内互联网信用支付产品,数据量爆发 ...
- 阿里云云开发平台助力风变科技Serverless架构升级实战
阿里云云开发平台助力风变科技Serverless架构升级实战 背景 风变科技 一个希望通过技术去推动下一代基础教育的组织.旗下产品包括第一代的熊猫书院(读书类产品).第二代的熊猫小课(泛学科综合学习平 ...
- Dapr Actor 的微服务架构
Dapr中的Actor模型,和Orleans的Virtual Actor一脉相传, 圣杰写过一篇文章Orleans 知多少 | .NET Core 分布式框架介绍过.简单来讲:Actor模型 = 状态 ...
- java架构之路-(Redis专题)redis面试助力满分+
1.Redis支持的数据类型? 答:五种,在第一节redis相关的博客我就说过,String,Hash,List,Set,zSet,也就是我们的字符串,哈希,列表,集合,有序集合五种.结构图如下. 2 ...
- 助力用户选择更优模型和架构,推动 AI机器视觉落地智能制造
智能制造的全新 "视界" 由互联网大潮掀起的技术进步,推动着智能制造成为传统制造行业面向未来.寻求突破的关键路径.通过融合机器人.大数据.云计算.物联网以及 AI 等多种技术, ...
随机推荐
- 面试官问,Redis 是单线程还是多线程?我懵了
我们平时看到介绍 Redis 的文章,都会说 Redis 是单线程的.但是我们学习的时候,比如 Redis 的 bgsave 命令,它的作用是在后台异步保存当前数据库的数据到磁盘,那既然是异步了,肯定 ...
- leetcode 1541. 平衡括号字符串的最少插入次数
问题描述 给你一个括号字符串 s ,它只包含字符 '(' 和 ')' .一个括号字符串被称为平衡的当它满足: 任何左括号 '(' 必须对应两个连续的右括号 '))' . 左括号 '(' 必须在对应的连 ...
- 干货 | Dart 并发机制详解
Dart 通过 async-await.isolate 以及一些异步类型概念 (例如 Future 和 Stream) 支持了并发代码编程.本篇文章会对 async-await.Future 和 St ...
- JavaScript获取URL参数方法总汇
现在做页面基本都用AJAX,因此导致操作很麻烦,每次都需要通过JS获取url中的参数值,网上所搜到很多资料,没一次能记住的,也不知道在哪个项目中使用过,现在又需要通过JS获取url参数,因此不能在偷懒 ...
- 初识WorldWind——WorldWind编译生成,解决乱码等问题
本文中World Wind的GitHub源码下载地址:https://github.com/hujiulin/WorldWind 美国国家航空航天局(National Aeronautics and ...
- Node内部架构图
1.Node内部架构图 先来看一下Node节点的内部实现架构图. 首先最上层入口是Restful风格和javaTcp风格的API入口,RestFul请求映射到处理器RestControl.JavaAp ...
- golang中int、float、string数据类型之间的转换
package main import ( "fmt" "strconv" ) func main() { var num1 int = 88 var num2 ...
- ambari-hadoop集群管理web工具
https://baike.baidu.com/item/Ambari/19697889?fr=aladdin https://www.ibm.com/developerworks/cn/openso ...
- SpringDataRedis入门到深入
一:简介 SpringDataRedis是SpringData开源项目中的一部分,它可以在Spring项目中更灵活简便的访问和操作Redis:原先在没有SpringDataRedis时往往使用Jedi ...
- 从我做起[AutoMapper实现模块化注册自定义扩展MapTo<>()].Net Core 之二
AutoMapper实现模块化注册自定义扩展MapTo<>() 我们都知道AutoMapper是使用的最多的实体模型映射,如果没有AutoMapper做对象映射那么我们需要想一下是怎么写的 ...