分布式应用程序需要依赖管理
分布式云应用程序(又名微服务)已将大量复杂性引入到云软件的设计和运营中。曾经的单体应用将复杂性隐藏在单个进程或运行时中,现在却分散在数十或数百个松耦合的服务中。尽管所有这些服务都可以使用不同的编程语言,并且可以彼此独立地进行扩展,但是分布式特性通常会使应用程序整体难以驾驭、难以部署并且很难保证安全。
这种新的复杂性使得管理和开发云原生应用程序变得越来越困难,并且引发了有关如何维护健康云软件的问题。我们如何才能利用面向服务设计的好处,而又不会在其他地方引入冲突和成本呢?
幸运的是,我们之前已经遇到过这个问题。微服务并不是第一种迫使开发人员弄清楚如何协作,并为无数互连组件操劳的模式。在过去的几十年中,这类问题的解决方案一直是相同的:依赖管理。
我们每天都使用依赖管理来重复使用公有和私有软件包,并在他人工作的基础上,将我们自己的应用优雅的封装为可用格式提供给其他人。依赖管理是释放分布式软件能力的关键,背后的原因有很多;现在是时候向过去学习,为云原生开发的未来提供动力了。