写点什么

“微服务并不是一切”:Fred George 谈论技术性、流程性与组织性障碍

  • 2016-02-29
  • 本文字数:2580 字

    阅读完需:约 8 分钟

在 microXchg 2016 大会上,Fred George 进行了一场主题为“微服务并不是一切”(It’s Not Just Microservices)的演讲。他在演讲中表示,微服务确实能够帮助组织“发展得更快”,并快速地交付商业价值。但他认为, 微服务的实现本身并不会带来成功,必须找到在技术、流程和组织等方面对业务的敏捷性增长造成阻碍的原因,并冲破这些阻碍。

George 是 Fred George Consulting 公司的首席顾问,他在演讲的开头部分首先表示,当前业界存在着许多“热门话题”,例如微服务、Docker 和精益创业,这些话题都是围绕着更快地交付商业价值的意愿而展开的。通过对于 Cynefin 框架的引用可以发现,许多组织所开展的业务是非常复杂的,由于这种复杂性,而无法确定因果关系,并且“目前有效的做法未必今后也同样有效”。因此,如果期望在应对这种复杂性时能够做到“更快地发展”,就必须找到在技术、流程以及组织方面的发展障碍并消除他们。

George 引入了技术性障碍这一概念,为了详细地讨论这一问题,他首先对“硅谷科技”的爆炸式发展进行了探索。在硅谷地区,有大量成功的商业组织充分地应用了云计算、专用数据库、开源框架与持续发布等技术,这就让其他组织开始反思,是否他们自身在技术方面的选择阻碍了他们的发展。尤其值得一提的是,如果组织将应用程序的部署从数据中心的裸机迁移至虚拟化的云平台以及基于容器的环境,那么就能够减少硬件的交付周期,进而缩短了应用的部署周期,这种差别往往是指数级的。

George 认为,由于硬件的交付周期缩短,再加上现代化的硬件平台具有更好的灵活性,这将促进服务设计的发展。久而久之,IT 产业的革新者逐渐开始从单一的一体性应用转变为由多个大尺度的面向服务架构(SOA)组成的服务。这一趋势最终演变为由多个小规模的单一职责(微)服务所组成的系统,由此带来了简化代码变更、缩小迭代规模以及更快的实践等优点。

通过不断发展的技术,我们将能够创建松耦合、高性能的应用架构,例如使用(利用 Kafka 等技术)持久化事件总线,并通过一个轻量级的消息代理(messaging broker)以减少对于核心事件总线(通过 Zero MQ 等技术实现)的读操作的负载。在同样由 George 所主持的另一场演讲“实现微服务所面临的挑战”( Challenges in Implementing Microservices )中,他还将对这一概念进行进一步的探索。

George 为听众举了一个车辆租赁业务领域方面的应用示例,该应用通过某个服务向事件总线发送一条消息,基于客户的数据发起一条租赁报价请求。而其他服务则能够对该请求发出出价的回复。通过这种松耦合、异步消息驱动的架构,就可以轻松地添加新的出价服务(例如某个开发者认为他们实现了一种改进型的出价算法),并且由于单一的出价服务不会造成整个系统出错的涟漪效果,从而也提升了系统的容错能力。

在关于如何缓解技术性障碍的讨论的总结陈词中,George 提出了开源所带来的爆炸性优势,如果组织无视一些现有的技术,例如 Netflix OSS 技术栈或 Docker ,那么就可能会将资源浪费在开发自有平台上。此外,George 还表示,对于某些用例来说,函数式语言或许能够成为解决问题的“银弹”。他提到了一个有趣的案例,某组织将一个包含 13 万行代码的 Java 遗留应用重写为基于 Clojure 的应用,仅用了 4 千行代码。

在演讲的下半部分,George 讨论了如何缓解流程上的障碍,而解决这一问题的关键在于首先要理解组织所开展的业务。对于明显或有一定复杂度的项目,可以通过传统结构的软件开发方式应对。但对于高复杂的问题则必须采用不同的策略。传统的“瀑布”模型的做法是在项目开始时为开发团队创建一个需求列表并进行任务分解,这种方式并不适合于处理复杂的问题领域,而应当采用“由实践驱动创新”的方式,开发者应该转而关注于“特性”层面,而不是继续停留在任务层面。

项目干系人应当直接与开发者讨论需要达成的业务目的、如何评价业务的成功,并且清晰地指出开发团队可以选择的“手段”。这一过程的关键在于“衡量重要的指标”,避免使用一些无用的指标,例如“代码行数”以及“完成的里程碑”,而应当使用一些专注于业务的指标,例如销售量、点击次数以及客户保留率等等。

在 George 谈论如何缓解组织性障碍的开始,他提出了一点建议,即应当避免开发团队任务的过度专业化。他发现,虽然理论上专职人员具有更好的生产力,但往往会受到过多的沟通与不均衡的工作安排的干扰,由此造成了工作的堆积与延误。George 为听众展示了某个组织的工作过度专业化的学习案例,他同时认为:各种漂亮的头衔对于项目的业务价值交付毫无意义。

我们有 50 位 IT 专家,其中超过 25 人有较高的头衔,但没有一个人理解他们所参与的项目的意义……

对于这个学习案例中所表现的过度专业化的问题,George 提出了一种解决方式,即创建一份简短的清单,列出对于组织有战略性重要意义的关键技术,并基于新手、熟练工及专家的模型创建相应的头衔。在这个学习案例中,新创建的头衔包括:“新手开发者”,即还未掌握某项技术的人员。“开发者”,即掌握了某项关键技术的人员。“高级开发者”,即某项关键技术方面的专家。“系统开发者”,即掌握了5 项或更多关键技术的人员。以及“开发者专家”,即3 项或更多关键技术方面的专家。

除了头衔的简化之外,另一个关键在于组织的工作空间的安排,这种安排的目的是让团队能够进行密切的合作,并且保证高效的沟通。团队应当实现“不设立专职主管”,以避免在团队中出现无谓的上下级结构,并且在处理因复杂的问题而出现不断变化的挑战时,这种方式能够带来更大的灵活性。而George 所提的最后一条建议是“将工作安排给固定的团队”,因为短期项目团队的组建与解散是一种低效的方式,团队需要一定时间才能够达到较高的生产力。

George 在本次演讲的总结中说道,虽然对于复杂的业务领域来说,微服务是一种解决问题的好方法,但只有处理好其他技术性、流程性与组织性障碍的问题,才能够有效地利用微服务交付商业价值。George 最后向参加此次专注于开发者的 microXchg 大会的听众传达了一条信息,他表示在开发团队中必须有系统管理员与运维人员的参与(“DevOps”),并且应当拥抱全栈开发者的观念。

Fred George 在 microXchg 的演讲“微服务并不是一切”的视频可在大会的 Youtube 专属频道上观看。

查看英文原文:“It’s Not Just Microservices”: Fred George Discusses Technology, Process and Organisation Inhibitors

2016-02-29 18:001718
用户头像

发布了 428 篇内容, 共 171.9 次阅读, 收获喜欢 38 次。

关注

评论

发布
暂无评论
发现更多内容

专业PDF编辑软件Acrobat Pro DC 2023 for mac中文破解版下载

影影绰绰一往直前

Downie 4 for Mac(mac视频下载)兼容14系统v4.7.2中文版

影影绰绰一往直前

Microsoft Office LTSC 2021 for Mac(office全家桶)v16.80中文正式版

影影绰绰一往直前

Sound Control for Mac(mac应用音量控制软件) 2.6.4中文激活版

mac

苹果mac Windows软件 sound control

软件测试/测试开发/全日制 | Python全栈开发:利用Docker实现应用容器化

测吧(北京)科技有限公司

测试

CloudXR在农业领域的用例表现

3DCAT实时渲染

CLOUDXR 云化XR

软件测试开发/全日制丨redis击穿、穿透区别,如何设计用例及测试

测试人

redis 软件测试 测试开发

软件开发项目延期,这么做项目保证按时交付

软件开发-梦幻运营部

想要了解华为IPD,先要了解需求如何管理!

华为云PaaS服务小智

需求管理 软件开发 华为云

AI大模型与低代码开发应用的完美融合

EquatorCoco

人工智能 AI 低代码 大模型

强大防护:如何选择最佳美国高防服务器租用服务

一只扑棱蛾子

美国服务器 美国高防服务器

React Native 打包 App 发布 iOS 及加固混淆过程

Axure RP 10 for Mac(交互式原型设计)v10.0.0.3912官方汉化版

影影绰绰一往直前

iZotope RX 10 for mac(音频修复和增强软件) 10.4.2完美激活版

mac

苹果mac Windows软件 iZotope RX 10 音频修复和增强软件

CSIG青年科学家会议圆满举行,合合信息打造智能文档处理融合研究新范式

合合技术团队

科技 大模型 合合信息 GPT-4

软件测试/测试开发/全日制 | 从HTML到React:Python全栈开发中的前端框架应用

测吧(北京)科技有限公司

测试

软件测试/人工智能/全日制 | Python全栈开发:理解HTTPS加密机制与安全传输

测吧(北京)科技有限公司

测试

Apache Paimon:Streaming Lakehouse is Coming

Apache Flink

大数据 flink 实时计算

程序员必备的数据库知识 2:Join 算法

快乐非自愿限量之名

云渲染电脑可以关吗?瑞云渲染客户端能断开网络吗?

Renderbus瑞云渲染农场

云渲染 渲染农场 瑞云渲染

软件测试开发/全日制丨面试题:中间件-淘汰缓存还是更新缓存

测试人

redis 软件测试 面试题 中间件 测试开发

Web3 生态系统中的稳定币发展:2024 年基本见解

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

圣诞节来临,如何用海外云手机给亚马逊店铺引流?

Ogcloud

云服务 手机云服务 云服务商

码上加速,低代码解锁高效交付案例

京东科技开发者

制造业企业使用SD-WAN的意义

Ogcloud

网络 SD-WAN 组网 组网网络

深入理解经典红黑树 | 京东物流技术团队

京东科技开发者

强大好用的低代码开发工具

这我可不懂

软件开发 crud 低代码开发 JNPF

亚太唯一,阿里云连续4年稳居Gartner全球云数据库报告「领导者」

阿里云瑶池数据库

数据库 阿里云 云原生 Gartner

海外网络加速:突破地域限制,畅联全球

Ogcloud

网络 网络加速 vpn 网络VPN

软件测试/测试开发/全日制 | Python全栈开发中的前端工具与构建流程

测吧(北京)科技有限公司

测试

免费部署试用的低代码开发工具分享(100%源码)

互联网工科生

低代码 JNPF

“微服务并不是一切”:Fred George谈论技术性、流程性与组织性障碍_方法论_Daniel Bryant_InfoQ精选文章