从敏捷开发到微服务,maybe再到中台
--
先说下准备这个的背景:
本来是想让我分享下敏捷开发,可能是听我说为as**搭建并完善了敏捷开发体系的原因吧。
我一般分享一个东西,希望大家能真的理解,而不只是知道。
我不大相信有万能的东西,不希望大家因为我说了,所以盲目的去套用,最后出了问题。
所以,这里讲下我对于开发模式这个东西的理解,主要说下敏捷开发的一些经验和小的tips。
可能大家也会对近两年很火的微服务感兴趣,所以顺带提一下。
$ 开发模式的意义
那么,讲这些有什么意义呢?
从大的出发点来说,比如灵硅的科技赋能至臻至善、滴滴的美好出行、抖音的记录美好生活、百度的让信息获取平等便捷,一个公司要为社会创造价值,才能受到大家的认可和支持,才能赚钱召集大家一起来创造更多的价值,形成良性循环。
从小的出发点来说,同样的工作强度,你自己能到大街上卖出公司给你的这么多薪水吗?我想很多人都是不能的。
人与动物的区别是,人会利用工具。
很多时候集体对个人的优势在于1+1》2,好的管理、协同方法能够让集体事半功倍,比如古代的战阵、现代的编队和美军的军用数据链。更直观一点,大雁的队形兼容不同年龄、体力,同时利用尾流集体省力;
开发模式就是软件工程中一种协同方法。
如果评判一种开发模式好还是不好的?我们要辩证的看待,考虑到现实需求情况和团队情况,包括团队的技能组成、需求的复杂耦合情况、目标的权衡情况等。
$ 首先,什么是敏捷开发
一般而言,有如下几种传统开发模式:
- 瀑布开发;(C的经典开发模式)
- 需求 -> 分析 -> 设计 -> 编码 -> 测试
- 特点:固定次序、不重叠
- 迭代开发;
- 迭代增量式开发、迭代固定式开发,俗称小步迭代
- 需求完全确定之前就启动开发,开发中不断精修细节
- 螺旋式开发;
- 计划 -> 风险评估 -> 实施 -> 客户评估 -> 计划 。。。
- 比迭代的循环粒度要大
- 瀑布开发;(C的经典开发模式)
$ 看敏捷开发(Agile program development)
以上三种开发模式,瀑布开发是顺理成章的,其他可以理解为瀑布开发形式的变种,主要变化在需求的粒度、确定性变化上。
敏捷开发会复杂点,我们先从几个名词来看(参考Link):
- agile - 敏捷的意思。在软件行业的核心:频繁迭代、修正,鼓励团队所有人的责任感、自主性(主人翁意识),快速、高质量的交互符合客户需求的产品。可以说是一个比较抽象的指导思想,我总结两个核心点:充分发挥团队中个人的作用,紧跟用户需求变化。
- scrum - 原意是橄榄球里的“列阵争球”,需要很高的技巧,也需要足够的身体对抗性、协调性、平衡感,可以灵活配以各种进攻策略。这里用在软件行业,算是敏捷里最常用的一种轻量级的process framwork,实践形式?
Scrum的几个主要特点:
- 生产效率高,耗时短,结果确定性较好;
- 能支持频繁变更的需求,甚至是拥抱变化;
- 计划和状态可控;
对于敏捷核心点的理解:
- 要快。两种选择,单核更快或者多核并发;一般只能选择并发,并发存在并发调度的问题,必然要拆解需求,小步迭代,小步融合。
- 要变。首先得兼容变化,设计的时候就要留有裕量;其次得及时交付上一个版本,才能及时安排下一个变化;再次,每个变化的需求基本都要是可用版本,才能不会为了变而变,丢掉了本质;
从这个角度来说,scrum在步子大小、拆分逻辑、融合方式、变化节奏、迭代过程上都给了一个确定的指导意见,基本适用于大部分的项目情况。
$ 从几方面具体看敏捷的实施的tips
这里从agile网站上抄过来的,和大家一起看下
- scrum的要求
- scrum的一些基本概念
- scrum有哪些角色
- 如何能做好呢?用来衡量敏捷的一些指标
- 异地分割的团队如何实施scrum
- 敏捷开发中DevOps的重要性
从腾讯云的漫画抄过来的Link
- scrum的要义不是工具,是不听的scrum
号称最全的agile tips:Link
来个总结,好落地的tips
很难有十全十美的事情,需要注意的,agile的问题 —— 合适的团队规模、需求复杂度、人员素质:
- 如何准确的评估问题
- 如何准确的评估自己的能力
- 如何准确的预估兼容性需求
- 合理的分工
- 合理的合作
- 如何合理的拆解
- 合理的引入敏捷工具,如git、gtd、wiki、Jenkins、燃尽图、甘特图等
$ 那么轮到微服务;
敏捷风靡业界,不管技术的老板也都知道敏捷了,所以有了更大维度的敏捷,产品维度的敏捷,其story就是微服务。当然老板来决定这件事是开玩笑的了。
那么我们来看下“微服务敏捷开发模式”,参考华为的案例,我最近也总结了一些经验
IBM的微服务简介Link
## 我欣赏以人为本、灵活变通的处事逻辑,但是千万记得灵活变通,万变不离其宗 —— 基于现实的效率提升!
从敏捷开发到微服务,maybe再到中台的更多相关文章
- Spring Boot 是 Spring 的一套快速配置脚手架,可以基于Spring Boot 快速开发单个微服务
Spring Boot 是 Spring 的一套快速配置脚手架,可以基于Spring Boot 快速开发单个微服务,Spring Cloud是一个基于Spring Boot实现的云应用开发工具:Spr ...
- EMIS快速开发平台 - 微服务版技术选型
http://demo.zuoyour.com/system/login EMIS快速开发平台 - 微服务版技术选型 开发框架:Spring Boot 2.1.3.RELEASE 微服务:Spring ...
- Otto开发初探——微服务依赖管理新利器
[编者按]时下,Vagrant 被 DevOps 软件开发商广泛作为开发阶段的本地软件开发环境,而在本文,CERT Division高级研究员介绍的 Otto 则是 Vagrant 开发团队 Hash ...
- zooland 新开源的RPC项目,希望大家在开发的微服务的时候多一种选择,让微服务开发简单,并且容易上手。
zooland 我叫它动物园地,一个构思很长时间的一个项目.起初只是觉得各种通信框架都封装的很好了,但是就是差些兼容,防错,高可用.同时在使用上,不希望有多余的代码,像普通接口一样使用就可以了. 基于 ...
- springcolud 的学习(二).微服务架构的介绍
什么是微服务微服务架是从SOA架构演变过来,比SOA架构粒度会更加精细,让专业的人去做专业的事情(专注),目的提高效率,每个服务于服务之间互不影响,微服务架构中,每个服务必须独立部署,互不影响,微服务 ...
- Spring Cloud 微服务架构整理记录与示例首页
---------------------------目录-------------------------------- 一.SpringCloud系列组件实战(Eureka.Ribbon.Hyst ...
- Dapr微服务应用开发系列0:概述
题记:Dapr是什么,Dapr包含什么,为什么要用Dapr. Dapr是什么 Dapr(Distributed Application Runtime),是微软Azure内部创新孵化团队的一个开源项目 ...
- 浅谈微服务架构、容器技术与K8S
关注嘉为科技,获取运维新知 企业应用系统:从单体应用走向微服务架构:从裸金属走向容器. 如果在诸多热门云计算技术诸如容器.微服务.DevOps.OpenStack等之中,找出一个最火的方向,那么可能非 ...
- Spring Cloud与微服务构建:Spring Cloud简介
Spring Cloud简介 微服务因该具备的功能 微服务可以拆分为"微"和"服务"二字."微"即小的意思,那到底多小才算"微&q ...
随机推荐
- 【转】DB2数据库编目的概念以及对其的正确解析
此文章主要向大家描述的是DB2数据库编目的概念以及对DB2数据库编目的概念的正确理解,在DB2中编目(catalog)这个单词看似很难理解,我自己当初在学习DB2数据库的时候也常常被这个编目搞的很不明 ...
- opencv利用svm训练
]]]]]])rand2 = np.array([[]]]]]])label = np.array([[]]]]]]]]]]])data = np.vstack((rand1]]])pt_data = ...
- 系统升级更新,cocoaPods不可用的问题
1.在终端运行: $ sudo gem install cocoa pods 会出现以下错误: ERROR: While executing gem ... (Errno::EPERM) Opera ...
- 洛谷 P5424 [USACO19OPEN]Snakes
题目链接 题目描述 传说,数千年前圣帕特里克消灭了哞尔兰所有的蛇.然而,蛇们现在卷土重来了!圣帕特里克节是在每年的3月17日,所以Bessie要用彻底清除哞尔兰所有的蛇来纪念圣帕特里克. Bessie ...
- TensorFlow or PyTorch
既然你已经读到了这篇文章,我就断定你已经开始了你的深度学习之旅了,并且对人造神经网络的研究已经有一段时间了:或者也许你正打算开始你的学习之旅.无论是哪一种情况,你都是因为发现你陷入了困惑中,才找到了这 ...
- JS ES6补充
补充点:1.let const 2.字符串模板 3.箭头函数 4.对象的单体模式 5.面向对象 一.定义变量 A.var 特点: 1.定义全局变量 2.可以重复定义 3.变量名提升 <!DOC ...
- restframework 视图
重要知识点 as_view()获取的是view方法名,当url配版成功,执行view方法 一.逻辑封装(mixins, generics) path('author/', views.AuthorVi ...
- java中5种异步转同步方法
先来说一下对异步和同步的理解: 同步调用:调用方在调用过程中,持续等待返回结果. 异步调用:调用方在调用过程中,不直接等待返回结果,而是执行其他任务,结果返回形式通常为回调函数. 其实,两者的区别还是 ...
- 机器学习环境配置系列二之cuDNN
1.下载cuDNN 前往: NVIDIA cuDNN home page. 进入下载 勾选Nvidia的协议复选框(流氓的选择,不勾选不能下载) 选择与安装的cuda版本一致的cudnn进行下载. 2 ...
- KALI美化-设置CONKY开机启动
简介 Conky 是一个应用于桌面环境的系统监视软件,可以在桌面上监控系统运行状态.网络状态等一系列参数 https://github.com/brndnmtthws/conky/ 详细配置文档:ht ...