为什么未来是全栈工程师的世界?

发表于:2016-4-11 13:19

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:程序师视野    来源:51Testing软件测试网采编

  谨以此文献给每一个为成为优秀全栈工程师奋斗的人。
  技术在过去的几十年里进步很快,也将在未来的几十年里发展得更快。今天技术的门槛下降得越来越快,原本需要一个团队做出来的 Web 应用,现在只需要一两个人就可以了。
  同时,由于公司组织结构的变迁,以及到变化的适应度,也决定了赋予每个人的职责将会越来越多。尽管我们看到工厂化生产带来的优势,但是我们也看到了精益思想带来的变革。正是这种变革让越来越多的专家走向全栈,让组织内部有更好的交流。
  你还将看到专家和全栈的两种不同的学习模式,以及全栈工程师的未来。
  技术的革新史
  从开始的 CGI 到 MVC 模式,再到前后端分离的架构模式,都在不断地降低技术的门槛。而这些门槛的降低,已经足以让一两个人来完成大部分的工作了。
  CGI
  二十年前的网站以静态的形式出现,这样的网站并不需要太多的人去维护、管理。接着,人们发明了 CGI (通用网关接口,英语:Common Gateway Interface)来实现动态的网站。下图是一个早期网站的架构图:
  当时这种网站的 URL 类似于: https://www.phodal.com/cgi-bin/getblog
  (PS:这个链接是为了讲解而存在的,并没有真实存在。)
  用户访问上面的网页的时候就会访问,cgi-bin 的路径下对应的 getblog 脚本。你可以用 Shell 返回这个网页:
  Blabla,各种代码混乱地夹杂在一起。不得不说一句:这样的代码在 2012 年,我也看了有一些。简单地来说,这个时代的代码结构就是这样的:
  这简直就是一场恶梦。不过,在今天好似那些 PHP 新手也是这样写代码的。
  好了,这时候我们就可以讨论讨论 MVC 模式了。
  MVC 架构
  我有理由相信 Martin Fowler 的《企业应用架构模式》在当时一定非常受欢迎。代码从上面的耦合状态变成了:
  相似大家也已经对这样的架构很熟悉了,我们就不多解释了。如果你还不是非常了解的话,可以看看这本书后面的部分。
  后台服务化与前端一致化架构
  在今天看来,我们可以看到如下图所示的架构:
  后台在不知不觉中已经被服务化了,即只提供 API 接口和服务。前端在这时已经尽量地和 APP 端在结合,使得他们可以保持一致。
  软件开发的核心难题:沟通
  软件开发在过去的几十年里都是大公司的专利,小公司根本没有足够的能力去做这样的事。在计算机发明后的几十年里,开发软件是大公司才能做得起的。一般的非技术公司无法定制自己的软件系统,只能去购买现有的软件。而随着技术成本的下降,到了今天一般的小公司也可以雇佣一两个人来做同样的事。这样的演进过程还真是有意思:
  在这其中的每一个过程实质上都是为了解决沟通的问题。从瀑布到敏捷是为了解决组织内沟通的问题,从敏捷到精益不仅仅优化了组织内的沟通问题,还强化了与外部的关系。换句话说,精益结合了一部分的互联网思维。
  瀑布式
  在最开始的时候,我们预先设计好我们的功能,然后编码,在适当的时候发布我们的软件:
  然而这种开发方式很难应对市场的变化——当我们花费了几年的时间开发出了一个软件,而这个软件是几年前人们才需要的。同时,由于软件开发本身的复杂度的限制,复制的系统在后期需要大量的系统集成工作。这样的集成工作可能要花费上大量的时间——几星期、几个月。
  当人们意识到这个问题的时候,开始改进工作流程。出现了敏捷软件开发,这可以解释为什么产品经理会经常改需求。如果一个功能本身是没必要出现的话,那么为什么要花功夫去开发。但是如果一个功能在设计的初期就没有好好设计,那么改需求也是必然的。
21/212>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号