文章中主要是一些概念,简单记录这段时间对 Istio 的学习。
对于全栈来说,学习 Istio 还是很有必要的,在此过程中还要学习 K8s、Docker 等基本的运维知识,那么在设计 BFF 层时候也会考虑到部署、扩容、金丝雀发布等问题,提升程序的健壮性。
JavaScript 全栈
在 JavaScript 流行的今天,各种框架层出不穷,无论是学习前端的 3 架马车(React\Vue\Angular)、还是运用后端的 Node.js 框架(Express\Koa\Egg.js)等,最后你都会前后端通吃,它们被 JavaScript 这门语言串联在了一起,尤其是当你去翻阅大量前端使用的 CLI 工具源码的时候,几乎都有 Express 的影子,所以在 JavaScript 技术栈里,前后端(这里的后端不是指复杂的后端架构和设计)本身并不分家。当然复杂的后端或前端工作并不适合全栈工程师去做,那也是后话了。
BFF 层
这些年来提出了 BFF 层的概念,根据业务的不同,不同公司有自己的设计和实现,比如将纯前端从 Nginx 移到了 Node.js Server 运行环境、服务端渲染(SSR)、生成或者拼接业务数据返回给前端使用(Node.js 微服务、GraphQL 等)…
Node.js 微服务
自己也做过很长一段时间的全栈,用 Node.js 开发后端业务,把数据吐给前端,不需要等着后端同事返回数据或者来回沟通的烦恼。现在做后端必定会遇到微服务的概念,不同的微服务有自己的 SDK 等工具帮助完成相关的注册发现,大多数情况下它们对 Java 的支持度最好,Node.js 有时候并不友善,要完善你不得不去写一些代码,比如熔断、报警等等,也是带来大量的开发测试成本。如果不幸公司内部 Java 组选择了不支持 Node.js 的架构,那么简直是灾难。
微服务的 SDK 基本上和网络通讯相关,下文的网络化可以解决这个问题。