第三,带有自身数据。
时间:2022-04-20 13:57:01 | 来源:行业动态
时间:2022-04-20 13:57:01 来源:行业动态
微服务不仅应带有自身数据,这些数据还应独立于其他微服务组件之外。在某些情况下,微服务甚至可能拥有自己的数据库。在其他场景中,微服务可能与其他服务共享同一套数据库,但仍在该数据库中拥有自己所对应的唯一数据库表。
通常来讲,开发人员会使用共享数据库以降低成本,但这明显违反了微服务架构的设计原则。
开发人员往往需要在设计中同时考虑到数据的独立性与冗余性。每项微服务自带数据的设计方式可能在应用层级上引发数据重复,但开发者们开始逐渐接受微服务设计模式必然引发数据冗余这一基本事实。
要了解不同微服务之间的数据重复问题,最直观的示例莫过于存储在不同在电子商务平台手中的客户数据。具体来说,同一用户很可能分别注册了Amazon与沃尔玛,因此两个网站都掌握着该用户的一套数据。但由于两个网站保持离散且隔离性极佳,因此除非拥有明确的数据访问授权,否则二者都意识到该用户的数据也存在于另一网站之上。