The Evolution of Web Service Architecture

This is a note of 《The Phoenix Architecture》, which mainly elaborates the evolution of web service architecture The original distributed system era Monolithic architecture SOA era Microservice era Post-microservice era Serverless architecture The future The evolution of website service architecture(网站服务架构的演进) 原始分布式时代 目标:构建 “符合 UNIX 的设计哲学的” “如同本地调用一般简单透明的” 分布式系统 结果:迫于现实,这个目标在一定时期内被妥协、被舍弃。但是,到了三十多年以后的将来(即 2016 年服务网格重新提出透明通信的时候),随着分布式架构的逐渐成熟完善,取代单体成为大型软件的主流架构风格以后,这个美好的愿景终将还是会重新被开发者拾起。 UIUD UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写。其目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。 远程方法调用和本地方法调用是不一样的 且不说远程方法不能再依靠本地方法那些以内联为代表的传统编译优化来提升速度,光是“远程”二字带来的网络环境下的新问题,譬如,远程的服务在哪里(服务发现),有多少个(负载均衡),网络出现分区、超时或者服务出错了怎么办(熔断、隔离、降级),方法的参数与返回结果如何表示(序列化协议),信息如何传输(传输协议),服务权限如何管理(认证、授权),如何保证通信安全(网络安全层),如何令调用不同机器的服务返回相同的结果(分布式数据一致性)等一系列问题,全部都需要设计者耗费大量心思。 AFS 分布式文件系统 源自 AFS 的分布式文件系统(Distributed File System,DFS)规范,当时被称为DCE/DFS 原始分布式时代的教训 Just because something can be distributed doesn’t mean it should be distributed....

January 30, 2023 · 3 min · Fenglyu