在文章亚马逊可持续软件工程实践[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 助力应用架构的可持续性的更多相关文章

  1. Dapr中国社区活动之 分布式运行时开发者日 (2022.09.03)

    自2019年10月首次发布以来,Dapr(Distributed Application Runtime,分布式应用运行时)因其"更稳定"."更可靠".&quo ...

  2. 京东云数据库 RDS助力企业便捷运维

    iPhone6发布那年,京东在国贸等商圈送货最快速度数分钟,包括从下单到送达.这是一个极端的富含营销因素例子.即便如此,常态来看,隔天到货的这种业务模式,也是基于同样的支撑:营销业务.物流业务,大数据 ...

  3. Dapr + .NET Core实战(十三)跨语言开发

    因为基于Dapr的服务架构是不限语言的,我们来看看Dapr的跨语言开发.我们使用golang,python,.NET来实现跨语言的服务调用,拓扑如下 我们继续使用.NET 5的fontend和back ...

  4. 【巨杉数据库SequoiaDB】巨杉数据库荣获《金融电子化》“金融科技创新奖”

    巨杉助力金融科技创新 2019年12月19日,由<金融电子化>杂志社主办.北京金融科技产业联盟协办的“2019中国金融科技年会暨第十届金融科技及服务优秀创新奖颁奖典礼”在京成功召开.来自金 ...

  5. Apache ShardingSphere 在京东白条场景的落地之旅

    京东白条使用 Apache ShardingSphere 解决了千亿数据存储和扩容的问题,为大促活动奠定了基础. 2014 年初,"京东白条"作为业内互联网信用支付产品,数据量爆发 ...

  6. 阿里云云开发平台助力风变科技Serverless架构升级实战

    阿里云云开发平台助力风变科技Serverless架构升级实战 背景 风变科技 一个希望通过技术去推动下一代基础教育的组织.旗下产品包括第一代的熊猫书院(读书类产品).第二代的熊猫小课(泛学科综合学习平 ...

  7. Dapr Actor 的微服务架构

    Dapr中的Actor模型,和Orleans的Virtual Actor一脉相传, 圣杰写过一篇文章Orleans 知多少 | .NET Core 分布式框架介绍过.简单来讲:Actor模型 = 状态 ...

  8. java架构之路-(Redis专题)redis面试助力满分+

    1.Redis支持的数据类型? 答:五种,在第一节redis相关的博客我就说过,String,Hash,List,Set,zSet,也就是我们的字符串,哈希,列表,集合,有序集合五种.结构图如下. 2 ...

  9. 助力用户选择更优模型和架构,推动 AI机器视觉落地智能制造

      智能制造的全新 "视界" 由互联网大潮掀起的技术进步,推动着智能制造成为传统制造行业面向未来.寻求突破的关键路径.通过融合机器人.大数据.云计算.物联网以及 AI 等多种技术, ...

随机推荐

  1. openGL绘图基本框架

    openGL绘图入门和导入外部文件 本文主要介绍通用绘图软件openGL的数据类型和基本的绘图框架,此外还提供了导入obj外部文件的方法,提供的代码稍作修改即可使用,希望能方便初学者快速上手. ope ...

  2. CTF-sql-宽字节注入

    本文章主要涉及sql宽字节注入注入的原理讲解,如有错误,望指出.(附有目录,如需查看请点右下角) 一.首先介绍一下本篇文章所用到的知识点: 常用到的url编码: 空格:%20 单引号:%27 在sql ...

  3. Android-ViewPager中调用notifyDataSetChanged失效问题--setItemPosition--POSITION_NONE

    最基本的方法: 针对于child view比较简单的情况(例如仅有TextView.ImageView等,没有ListView等展示数据的情况),可以在自己的Adapter中加入代码: @Overri ...

  4. Java传递变量和对象的区别

    传递对象 public class Demo03 { //引用传递:(实际上还是值传递)对于引用数据类型来说,传递的则是地址的副本(对象的地址).但由于地址副本和原来的类似,因此传递过去后形参也只想同 ...

  5. Solon Web 开发,五、数据访问、事务与缓存应用

    Solon Web 开发 一.开始 二.开发知识准备 三.打包与运行 四.请求上下文 五.数据访问.事务与缓存应用 六.过滤器.处理.拦截器 七.视图模板与Mvc注解 八.校验.及定制与扩展 九.跨域 ...

  6. winform全局异常处理

    static void Main() { //设置应用程序处理异常方式:ThreadException处理 Application.SetUnhandledExceptionMode(Unhandle ...

  7. 雷柏鼠标vt350Q配对

    vt350q 闲鱼捡了个垃圾vt350q,23元,无接收器,不知道好坏 鼠标线 拿到手插上线没法用,后来用了罗技anywhere2s的线可以,原来usb鼠标线是五根. 鼠标毛病 使用后发现滚轮有时候乱 ...

  8. 【转载】ASP.NET 内联代码、内联表达式、数据绑定表达式使用方法罗列(形式就是常说的尖括号 百分号 等于号 井号)

    ASP.NET 内联代码.内联表达式.数据绑定表达式使用方法罗列(形式就是常说的尖括号 百分号 等于号 井号) 今天在做渭南电脑维修网的一个小功能时遇到了一些问题,因此特别列出,以备他日之用. 首先对 ...

  9. 515. Find Largest Value in Each Tree Row

    You need to find the largest value in each row of a binary tree. Example: Input: 1 / \ 3 2 / \ \ 5 3 ...

  10. 在 K8S 中快速部署 Redis Cluster & Redisinsight

    Redis Cluster 部署 使用 Bitnami helm chart 在 K8S redis 命名空间中一键部署 Redis cluster . helm repo add bitnami h ...