事件驱动架构为何让开发者又爱又恨:从事件溯源到CQRS的十五年技术博弈
2011年,一位名叫Greg Young的开发者在一次技术会议上提出了一个看似简单的想法:如果我们不再存储对象的当前状态,而是存储导致状态变化的所有事件,会怎样?这个想法后来被称为事件溯源(Event Sourcing)。十五年后的今天,事件驱动架构已经成为微服务系统的核心范式,但它的复杂性也让无数开发者痛不欲生。 ...
2011年,一位名叫Greg Young的开发者在一次技术会议上提出了一个看似简单的想法:如果我们不再存储对象的当前状态,而是存储导致状态变化的所有事件,会怎样?这个想法后来被称为事件溯源(Event Sourcing)。十五年后的今天,事件驱动架构已经成为微服务系统的核心范式,但它的复杂性也让无数开发者痛不欲生。 ...
1984年,Birrell和Nelson在ACM Transactions on Computer Systems上发表了一篇划时代的论文《Implementing Remote Procedure Calls》。他们提出了一个简单而强大的构想:让程序员能够像调用本地函数一样调用远程服务器上的过程,完全屏蔽底层的网络通信细节。四十年后的今天,这个构想已经成为微服务架构的基石——从Google的gRPC到阿里巴巴的Dubbo,RPC框架支撑着全球数十亿用户的服务调用。 ...
2016年,某电商平台在双十一促销中遭遇了诡异的服务调用超时。排查后发现,问题并非来自业务代码,而是服务间的网络通信层——每个微服务实例旁边都跑着一个Envoy代理,它们在处理mTLS加密、流量统计、熔断检测等任务时,竟吃掉了30%的CPU资源。这不是一个孤立的案例,而是一个技术演进过程中必然会暴露的深层矛盾:我们为了解决微服务通信的复杂性,引入了一个新的复杂层。 ...
2012年,Netflix的工程团队做了一个看似疯狂的决定:在生产环境中主动注入故障。他们开发的Chaos Monkey会随机终止生产服务器实例,以此验证系统的容错能力。这个看似激进的实践背后,是一个深刻的认知:分布式系统中,故障不是会不会发生的问题,而是什么时候发生的问题。 ...
2012年9月,Netflix开源了一个名为Eureka的项目。这不是一个全新的技术发明,而是一个针对AWS云环境的妥协产物。然而,这个妥协引发了微服务社区长达十年的争论:服务注册中心到底应该优先保证一致性还是可用性? ...
2017年,Istio 1.0发布。Google、IBM、Lyft三巨头联手打造的服务网格项目,被寄予了重塑微服务通信的厚望。当时的技术媒体甚至用"微服务的最后一公里"来形容它——仿佛只要装上服务网格,所有分布式系统的难题都将迎刃而解。 ...
Uber的调度系统曾经遇到过一个难以复现的诡异bug:location-service → driver-service → trip-service → location-service,形成了一个完美的循环调用链。这个bug只在特定条件下触发——当司机和乘客恰好处于同一个geohash网格中时。在测试环境中,这个条件几乎不可能被满足,因此问题长期潜伏。直到某次高峰期,大量用户在相同区域,循环依赖终于暴露,系统负载瞬间飙升。 ...