想成为全栈工程师,要做到哪几点?

2020 年 10 月 14 日 阿里技术

阿里妹导读:如何成为一名全栈工程师?需要具备哪些技术积累?成为全栈工程师有哪些好处希望本文能为期望成为全栈工程师的同学提供一点帮助,和同学们一起分享交流。


文末福利:超全学习资料,免费领。


作为开发者,我们不过度区分服务端 server 客户端 client,我们是 web developer,从事 web 开发,多去理解技术和实践落地。

成为全栈工程师的道路

成为全栈工程师说不上难也说不上容易,其中技术积累占了很大一部分:

紧跟前沿

掌握足够 多的输入。

关注海外社区新消息发布,业界的新产品新技术,学会高质量的获取信息,坚持做和习惯做。

注重学习 & 不断实践

有属于自己的思考和严谨的产出。

掌握高效学习方法,比如我们最近在做 k8s 容器集群相关的事情,需要理解底层设计和做集群调度,需要学习 Golang,新技术的学习过程:

  • 投资一个好的 IDE,例如 Webstorm、Goland、IntelliJ IDEA 等,坚持使用。


  • 认准官方文档,坚持学习。


  • API 手册查看,不断熟悉和记忆。


  • 写学习总结,形成良性循环:定义功能 -> 代码设计 -> 完成功能 -> 重构优化 -> 优化代码设计 -> 完成 -> 重构 -> 完整掌握。


总结:实践贵在坚持,面对新的未知的领域,也要迎难而上。

重视基础知识 & 多做总结

理解清楚,事半功倍。

例如作为 Web Developer:

  • 必备知识:语言基础,Web 应用的基础,熟悉 Linux 运行环境,网络传输过程 HTTP 协议,TCP 协议。


  • 进阶知识:熟悉浏览器请求过程,Web Server 端口监听原理,数据库原理,浏览器请求原理,应用程序安全通信 TLS 协议,数据加密解密方案,数据签名方案。


  • 架构层面:应用分层模式,数据模型定义模式,微服务划分思路,系统设计模式。


作为无线团队:收益最大的和最值得投资的部分

把这些最常见的问题背后的原理理解清楚,就能独立解决绝大多数问题,提升全链路研发效率,和各个岗位的人沟通无障碍,协作无阻力。

要做一件事情,出什么方案最合适,什么角色来做最适合,采用什么样的技术架构更合适:

  • 语言是最基础的:HTML/CSS/Javascript/ECMAScript/Typescript/Node.js/Golang/Java 等。


  • 网络协议层 HTTP 协议,DNS,7层/4层负载均衡,这里会涉及到服务端,前端,SRE,网络安全等各个岗位的基础知识。


  • 框架层原理和细节:应用框架 React/Koa/Spring,数据库框架,安全组件。


  • 结合公司技术体系衍生的框架层约定和业务框架:阿里/蚂蚁中间件。


  • 工程化 :CI/CD 持续集成,自动化测试,代码构建发布过程。


  • 基础设施 IaaS:私有云、混合云、公有云。AWS、阿里云等。


对团队带来的价值:

  • 由于无线的特点:会遇到的问题 HTTP 协议相关的占比很大,端上的性能优化,网路异常处理,前后端交互的基本过程。线下调试遇到时能快速定位和修复,线上遇到问题时,能第一时间做出快速的决策。


  • 不是所有问题都是靠经验可以弥补的,人在很多时候会重复犯错,就怕遇到重复的问题还是找不到根因,所以需要从源头上解决,还是要掌握全栈基础知识。


总结:

  • 基础知识理解清楚,在使用上层的技术,例如各种框架和运维体系时,可以快速看到使用的技术背后的本质是什么。


  • 能减少犯错几率,做更多正确的决策。


全栈技术体系实践

三人行必有我师,向身边的人学习。

举个我现实中身边的人例子:在做登录鉴权用户体系,先把系统设计好,数据模型设计,接口设计,最后是实现,最重要也有价值的部分是前期的设计阶段。最后分别用 Node.js、Java、Golang 实现了一遍,不同语言和框架间的实现都是类似的,功能的移植非常快,可以并行进行。

而设计出好的代码需要的先决条件,也是和前面的基础部分的掌握完全匹配的,基础越好,设计得也越好。

总结:

  • 优秀的设计不仅做出的系统可靠,设计得也简单清晰易懂。


  • 写的时候没有负担,维护的时候也没有高昂成本。


避免陷阱

全栈不代表降低要求,全栈是为了提升开发效率,如果质量差,不好维护,反而降低了团队效率。

  • 避免只是多涉猎,而缺少实战,看过不等于会运用。


  • 能写全栈不代表写出的代码能上生产环境,避免给自己下意识地降低要求,写出的代码质量不过关就违背了全栈的初衷。


成为全栈工程师的好处

掌握前后端服务端全链路知识体系和核心知识点

  • 提高研发效率,提升解决问题能力,提高排查问题效率,可以快速侦破问题,及时处理问题。


能理解不同岗位的同学的诉求

  • 后端同学:能理解为什么前端同学会对接口字段提出很高要求,期望后端提供的接口按照开源社区的标准来定义(好的接口是自说明的,不用过多的文档,遵循业界 API 设计规范,使用接口符合人的直觉,接口字段稳定)。


  • 前端同学:能理解为什么后端同学不愿意轻易写特殊逻辑判断(一套模型已经定义得很优雅了,加个特殊分支就破坏了代码的一致性)。


  • 研发同学:能理解为什么运维同学不愿意轻易给运维权限(底层运维一旦操作不当,做成的破坏力太大,需要深厚的技术积累)。


知识面不全面的反例

真实的反例:全栈有 助于减少低级错误的出现

这里的例子都是我曾经参与解决过问题的,过程中我看到的是:这些都不是什么高深的问题,这些都是由于知识面不全面才发生问题:

  • 应用服务上线,服务器配置 nginx 代理线上 CDN,返回 502 了,开发和 SRE 一起排查下来是没有开公网访问权限(原因:应用 owner 不熟悉网络知识和运维体系,没有和 SRE 打好配合)


  • 前端域名和后端域名不同,浏览器请求失败,因为有跨域问题(原因:不熟悉 HTTP 协议中的 header 运用)。


  • 后端接口名字设计有歧义,不规范,不满足  RESTful API 规范(原因:不熟悉基于 HTTP 协议的规范,本质上是 HTTP 的 中 method 的运用)。


  • 其他例如 websocket 问题,前端性能优化,缓存相关等问题排查效率低(原因:绝大多数跟不熟悉 HTTP header 有关)。


最后

我始终觉得全栈不是认证证书,不需要有人给你做认证,当你能获得不同技术栈的同学的信任时,就是对你最大的肯定。



  福利来了  
超全学习资料免费领


开发者如何自我提升?如何拓展自身技能,补齐技术短板?阿里巴巴有哪些技术沉淀,如何学习借鉴?阿里技术免费开放超全开发者学习资料,涵盖各领域的上百本阿里系技术电子书、各种技术大会资料合集、知识图谱、面试宝典等,助力所有开发者共同学习进步!


识别下方二维码加「阿里妹」微信好友,回复 “资料大全” 立即领取吧~



戳我,去开发者课堂。
登录查看更多
0

相关内容

【2020新书】使用Kubernetes开发高级平台,519页pdf
专知会员服务
66+阅读 · 2020年9月19日
【2020新书】高级Python编程,620页pdf
专知会员服务
235+阅读 · 2020年7月31日
【干货书】现代数据平台架构,636页pdf
专知会员服务
253+阅读 · 2020年6月15日
打怪升级!2020机器学习工程师技术路线图
专知会员服务
98+阅读 · 2020年6月3日
Python导论,476页pdf,现代Python计算
专知会员服务
259+阅读 · 2020年5月17日
阿里技术大牛:一份架构师成神路线图!
51CTO博客
30+阅读 · 2019年7月6日
阿里技术专家:优秀工程师是怎样炼成的?
51CTO博客
8+阅读 · 2019年6月15日
使用 C# 和 Blazor 进行全栈开发
DotNet
6+阅读 · 2019年4月15日
Arxiv
0+阅读 · 2020年12月3日
Arxiv
0+阅读 · 2020年11月30日
Arxiv
7+阅读 · 2018年11月27日
Arxiv
23+阅读 · 2018年10月1日
Arxiv
20+阅读 · 2018年1月17日
VIP会员
相关VIP内容
【2020新书】使用Kubernetes开发高级平台,519页pdf
专知会员服务
66+阅读 · 2020年9月19日
【2020新书】高级Python编程,620页pdf
专知会员服务
235+阅读 · 2020年7月31日
【干货书】现代数据平台架构,636页pdf
专知会员服务
253+阅读 · 2020年6月15日
打怪升级!2020机器学习工程师技术路线图
专知会员服务
98+阅读 · 2020年6月3日
Python导论,476页pdf,现代Python计算
专知会员服务
259+阅读 · 2020年5月17日
相关论文
Arxiv
0+阅读 · 2020年12月3日
Arxiv
0+阅读 · 2020年11月30日
Arxiv
7+阅读 · 2018年11月27日
Arxiv
23+阅读 · 2018年10月1日
Arxiv
20+阅读 · 2018年1月17日
Top
微信扫码咨询专知VIP会员