简介:每一个工具的诞生,都要有一个成长的过程,Serverless Devs 正在不断的成长。

从我做 Serverless 工具开始,就经常会遇到有人问这样一个问题:如何保证Serverless业务部署更新的一致性。

所谓的一致性在这里指的是:我们通过工具在本地进行项目部署,此时再有人通过其他途径(例如控制台等),对项目进行过更新等操作,此时我再在本地进行项目部署,是不是会直接覆盖?

例如,当用户 A 在本地更新了业务,因为一些特殊情况,导致出现了一个线上异常情况“x”,此时用户 B 重新更新,将这个内容修复了,但是 B 没有及时同步给 A 这个事情,A 又更新了新的功能,直接覆盖了 B的内容,这个时候之前的异常 x 又出现了,如果此时在 A 更新的时候,可以感知到线上资源已经变动,那么这种事情就不会再次发生。

目前基于 Serverless Devs 的阿里云函数计算组件,已经支持了线上“异动”的感知能力,包括了以下几个情况:

  1. 本地新建并部署一个线上没有的资源
  2. 本地部署完成,线上更新,本地再次部署
  3. 本地新建并部署一个线上已经有的资源

实验准备

通过s init创建一个函数(选择Alibaba Cloud Serverless, 选择HTTP Function - Python3 Example):

此时我们查看一下s.yaml:

该项目部署到线上之后的表现就是在cn-hangzhou区创建一个fc-deploy-service服务,以及http-trigger-function函数

本地新建并部署一个线上没有的资源

此时,我们确定一下线上并没有对应资源,所以我们部署一下:

部署完成,很顺利:

打开浏览器,查看反馈给我们的自定义地址:

此时,我们可以在本地,更新一下这个函数代码:

保存部署:

完成之后,再查看线上资源:

整个过程,还是比较贴近传统的基本流程,也没有触发线上异动,算是中规中矩的理想过程。

本地部署完成,线上更新,本地再次部署

此时,我们对线上资源进行变更,首先在控制台找到函数:

修改代码,并部署。

部署完成之后,我们刷新一下刚才的地址:

可以看到已经更新。此时,我们再从本地进行部署:

可以看到,系统已经感知到我们的代码变化,此时,我们选择yes,完成之后在查看线上资源:

此处需要额外说明的是,只要是函数计算的服务,函数,触发器发生变化,此处都可以进行感知,不管是配置还是代码。

本地新建并部署一个线上已经有的资源

此时,我们再进行最后的实验,我们将本地项目删除,重新建设。然后执行部署,由于刚刚实验过的原因,我们已经在线上存在了这些资源,所以此时算是部署一个线上的资源。

此时可以看到,系统感知到这个资源本地没部署过,线上并且已经存在,所以此时需要确定是否覆盖。

总结

代码在其他场景被更新,需要我们在当前得到感知,这个事情其实是非常重要的,和代码的安全发布密不可少。而此时,通过Serverless Devs是可以做到的。

那么问题来了,如果我已经有了一个项目,我想集成到cd流程,我不想出现交互式操作,应该如何处理呢?

此时我们提供一个--use-local参数,用来强行覆盖线上配置,通过这样的指令就可以实现无交互的,本地优先。

每一个工具的诞生,都要有一个成长的过程,Serverless Devs正在不断的成长。期待更多更好的功能出现。

原文链接:https://developer.aliyun.com/article/785431?

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

如何保证 Serverless 业务部署更新的一致性?相关推荐

  1. 8种方案,保证缓存和数据库的最终一致性

    前言 我们通常使用缓存机制来提升系统的性能,缓存系统下的读写操作,一般都需要操作数据库与缓存. 对于读操作,一般是先查询缓存,查询不到再查询数据库,最后回写进缓存. 而对于写操作,究竟是先删除(更新) ...

  2. 代码评审-如何保证缓存与数据库的读写一致性?

    我们从近期代码评审过程中的一段代码,开始探讨缓存和数据库的一致性问题. 探讨前置 一般来说,使用缓存主要为了提升应用性能和降低DB的直接负载,从场景上来说可以接受最终一致性方案, 如果业务场景要求 & ...

  3. 实践《如何使用Seata保证Dubbo微服务间的一致性》

    原文在这里:如何使用Seata保证Dubbo微服务间的一致性. 从这里下载sample代码,master分支,最新的代码提交日期是2019.9.16,修订号cd10c5a.本文代码在模块dubbo里. ...

  4. 预约活动(秒杀)项目中如何高效的保证下单交易成功?保证redis,mysql的最终一致性?

    预约活动(秒杀)项目中如何高效的保证下单交易成功?保证redis,mysql的最终一致性? 前言 `在秒杀项目中,秒杀下单的过程中都需要经历四步,分别为: 1.校验下单状态,商品是否存在,用户是否合法 ...

  5. 如何保证数据库和缓存双写一致性?

    前言 数据库和缓存(比如:redis)双写数据一致性问题,是一个跟开发语言无关的公共问题.尤其在高并发的场景下,这个问题变得更加严重. 我很负责的告诉大家,该问题无论在面试,还是工作中遇到的概率非常大 ...

  6. 服务器硬件和算力,硬件科普Filecoin运维交付之业务部署

    随着Filecoin存储体量的不断增加,"运维"的重要性在这个行业里也愈发凸显.如何将每个环节的各种因素变得可控:一方面需要对硬件环境进行预检措施,以高效应对突发事件:另一方面也需 ...

  7. WSUS补丁服务器部署详细 利用WSUS部署更新程序

    WSUS补丁服务器部署详细 利用WSUS部署更新程序 https://www.cnblogs.com/Summer6/p/10921491.html WSUS概述 为了让用户的windows系统与其他 ...

  8. 利用WSUS部署更新程序

    WSUS概述 为了让用户的windows系统与其他microsoft产品能够更安全,更稳定,因此microsoft会不定期在网站上推出最新的更新程序供用户下载与安装,而用户可以通过以下方式来取得这些程 ...

  9. 14 | 代码模型(下):如何保证领域模型与代码模型的一致性

    14 | 代码模型(下):如何保证领域模型与代码模型的一致性 Reference DDD实战课

最新文章

  1. 保存ip地址和计算机名称,批量设置IP地址和计算机名
  2. java map 结构体_业务代码的救星——Java 对象转换框架 MapStruct 妙用
  3. linux 爬虫工具,技术|如何在Ubuntu 14.04 LTS安装网络爬虫工具:Scrapy
  4. 三维重建:三维空间中平面的旋转公式
  5. 华为机试支持python吗_4.10华为暑期实习生机试题目,python解答
  6. makefile例子(经典)
  7. iOS开发值多线程简单介绍
  8. en 2014-12-31
  9. 一道实用linux运维问题的9种shell解答方法!
  10. 财务有必要学python吗-财务人要学Python吗?
  11. javascript createelement_如何创建与框架无关的JavaScript插件
  12. UI自动化测试(APP测试)
  13. matlab绘制不同线性的直方图,matlab绘制直方图
  14. python目前版本强势英雄_最强竟然不是灭霸|用Python给漫威和DC英雄综合实力排位...
  15. 网易校招测试岗位2018
  16. 微信公众号关注自动回复得到小程序链接
  17. BJTU1940 铁憨憨骑士团的回文对称
  18. 免费电子书 工具 开发工具包 各类资源 下载 .
  19. Android Studio 调试的时候出现 Access denied finding property “ro.serialno“
  20. excel从右边查找字符并截取

热门文章

  1. SparkSQL之External Data读写parquet
  2. 推荐:两款实用的Jupyter插件~
  3. c语言判断用户名重负,判定方阵的正定负定在C语言中写法.docx
  4. visio网络拓扑图_人船模型怎么画?分享高颜值模型图软件
  5. 应用计算机基础1答案,2017年计算机应用基础习题及答案
  6. [转] Oracle中Blob转Clob
  7. vue 点击倒计时 ajax 封装
  8. OutOFMemoryError
  9. Aop和Filter区别
  10. hdu5698瞬间移动(组合数,逆元)