云计算是如何拯救软件工程的?

本贴最后更新于 2634 天前,其中的信息可能已经沧海桑田

  我之前有一个观点:前些年软件工程,或者说软件工业化的发展是倒退的!长期以来我坚持着这个观点。直到云计算的到来,我觉得这应该会是软件工业化的方向。今天和大家聊聊为什么说云计算会带领软件行业走向属于自己的工业化道路。

  政治课本告诉我们,随着一个产业的发展产业技术必将趋向于复杂。面对越来越高的复杂性,会出现更细致的分工,每个分工都会更专注于自己的领域。从社会结构来说,必然会出现专业的组织来提供专业的解决方案和提供有针对性的产品。

  软件行业也进行过这样的尝试:软件外包。软件的低边际成本也曾造就了离岸外包这种工业化生产的模式。我一度认为这是一种理想的软件工业化生产方式,因为这种方式与传统工业生产的方式太像了。但是软件这种产品天生具有其特殊性,他是组织生产、运营过程的信息化抽象。在企业运作中,必然出现业务与流程的变更。在没有软件的时代,进行这样的变更只需要一纸命令,员工自然变更工作流程,似乎大家也能很快适应继续生产。但有了软件就不同了,每次流程、业务变更意味着软件的变更,原本一纸通知,调整几个人就能解决的事情变成了软件的修改,传统软件开发流程又极其冗长,最终造成了客户的不满。毕竟软件行业太年轻了,更何况相比其他工业产品它的变更成本太低了:你不会在今天刚刚搬进的新家里要求将卧室改成阳台,下周把厨房和卫生间调换位置,也不会要求你脚下的汽车油门和刹车改成由手操控,更无法想象三天两头将医生将诊断标准换一换。而外包软件的生产模式和多变的产品需求的不匹配造成了软件外包这种做法根本无法适应场景。外包这种模式似乎已经成了这个行业的糟粕,说出口就要被嫌弃。

  软件外包的尝试只能草草收场,特别是针对组织定制的软件外包仿佛成了一个笑话。但生活还是要继续,没有软件的支撑就意味着效率的低下。怎么办?自己干!于是各家公司轰轰烈烈地组织起自己的研发队伍来。有钱的队伍就大一点,没钱的队伍就小一点。特别有钱的壕企都组成了自己内部的软件公司,只为自己服务。这些公司的软件团队越来越强大,每家都有自己的强悍的基础软件产品。你看看,国内开源了多少数据库了?MQ 就更不用提了!RPC 也每家自己来一套!整个行业好不热闹,一幅欣欣向荣的样子。

  每个组织都倾向于自己造一套轮子,哪怕这个轮子是方的也在所不惜,毕竟自己的娃怎么看都长得俊。哪怕是捡来的娃,好好喂养两年,打扮一番也比别人的娃要好。细致分工?前两年还轰轰烈烈地炒起了全栈工程师概念!我还记得小时候我妈他们单位有医院,有学校,有自己的建筑工程队,单位的房子都是自己造的,好像还想自己造拖拉机来着。与如今的软件行业何其像?每个技术团队恨不得所有东西都自己造。

  隐藏在这些热闹吆喝下的是什么? 是社会资源的极大浪费! 而随着软件技术的发展,复杂性越来越高,很多东西再也不是几个人拉个小作坊就能搞定的了。大数据解决方案,人工智能解决方案,语音图像识别方案...这些还是普通公司能背负的起的轮子么?别忘了市场上 90% 以上的公司都是小公司啊!

  此时,我们问问自己的初心:我们要的究竟是什么?我们要的不是数据库,不是 MQ,不是 RPC,不是精巧的框架!我们要的是能提升效率的软件产品!我们要的是能解决我们问题的信息化工具!但是,为什么我们要为这些本不关心的东西承担那么大的研发成本?为什么我要盖楼还要雇佣人烧砖?为什么我想要辆车却要架高炉炼钢?为什么我要吃碗饭还要下地插秧?不,这一定不是他本该有的样子!

  但最初的问题依然在,软件功能的不稳定性并没有因此烟消云散。怎么办?那些强悍的研发团队灵光一现:那些研发成本最高的东西其实和业务相关性并不强,我们可以把这些东西拿出去卖呀!怎么卖?再卖给人家一堆产品叫别人部署维护管理肯定不行,成本还是太高了。干脆,这些远离业务的事情我们都做掉吧!你们来用就好了!云服务就这样诞生了。负载均衡高可用;无限容量大存储;海量数据可视化...来吧,别自己开发了直接用就行,价格比养一群人做基础组件的研发不知便宜到哪边去了,把省出来的时间金钱拿去扩大市场,优化业务吧。就这样,把原本专为自己服务的组件公开了,大家一起来使用,研发成本摊平了,业务实现轻松了。这样所创造的社会价值不知比造轮子自嗨高到哪里去了!

  我想,这是一次很大的进步,虽然并没有从根本上完全解决软件需求个性化的问题,但已经是一次大大的工业化进步。很大程度上缓解了人民日益增长的信息化需求与软件研发成本飙升之间的矛盾。而我很欣慰地看到,随着云计算的推广,大家的思路变得越来越清晰:降低应用软件开发的门槛和成本成为了一个明确的方向。我想,终有一天软件产品也能成为一件普通的工业品通过流程化和细致化的生产流程进入到每个人的手中,它廉价而灵活。而那时的程序员,应该再次回到组织集中化的生产环境中来,发挥技术规模优势更好地为终端用户提供简单易用的服务,让用户方便快捷地获得高度定制的软件产品。让软件回归工具这一本质,成为螺丝刀、锤子一样的生产辅助工具,而不再是居高不下的研发成本造出的五花八门的轮子。解放出生产力,用这个工具更好地创造价值。

打赏 1 积分后可见
1 积分
  • 云计算
    79 引用 • 91 回帖 • 1 关注
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    142 引用 • 442 回帖 • 3 关注
  • 软件工程
    29 引用 • 81 回帖
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    588 引用 • 3528 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 97 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 279 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    496 引用 • 934 回帖 • 1 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 342 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖 • 7 关注
  • gRpc
    11 引用 • 9 回帖 • 99 关注
  • 自由行
    1 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    240 引用 • 224 回帖 • 1 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25914 引用 • 107392 回帖 • 2 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 36 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    43 引用 • 44 回帖 • 2 关注
  • OneDrive
    2 引用 • 3 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    298 引用 • 763 回帖
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 1 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 152 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    167 引用 • 597 回帖
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 233 回帖 • 3 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 65 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 250 关注
  • 安全

    安全永远都不是一个小问题。

    199 引用 • 818 回帖 • 1 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 708 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 734 关注