官术网_书友最值得收藏!

Combining data

In a monolithic environment, combining data is easy; you need to just join two tables to create the required view. In microservices, datasets are distributed across microservices and combining them requires moving the data across microservices, which may involve significant network and storage overhead. It also becomes challenging to keep the combined data up to date. There are multiple ways to solve the problem of combining data or joins in a microservices architecture based on the scope of the request.

For example, if you wish to build an order summary page for a particular user, you need to get only that user's data from the User Service and all the orders for that user from the Orders Service. These can be obtained independently and joined at the requesting service level to generate the order summary, as shown in the preceding diagram. These kinds of join work well for 1:N joins.

Real-time joins work well for limited datasets, but it is expensive to combine data in real time for each request. Imagine tens of thousands of similar requests hitting the Order Summary Service every second. In such scenarios, services should instead keep denormalized (https://en.wikipedia.org/wiki/Denormalization) combined data in a cache that is kept up to date using the events generated by the source services. The service can then respond to the requests by just looking up this denormalized data cache in real time. This approach scales well at the expense of data being near real time. The data in the cache might be off by the time source service generates the event and target service picks it up and makes changes to its cache.

For example, as shown in the preceding diagram, an Interest Service may receive user interests via its API endpoint, but it may need the user and order details from the User and Orders services respectively. Instead of directly looking up details for each user interest, the Interest Service may subscribe to the events generated by the user and orders service and internally keep a denormalized cache view of interest data that is readily available with all the required details of users and orders.

主站蜘蛛池模板: 武宣县| 会昌县| 邻水| 宁陵县| 凤凰县| 行唐县| 孟连| 随州市| 五大连池市| 大渡口区| 阳谷县| 浙江省| 绥江县| 双鸭山市| 无极县| 波密县| 周口市| 阿克| 准格尔旗| 孝昌县| 安多县| 湛江市| 正定县| 东辽县| 万山特区| 龙游县| 定陶县| 南部县| 丁青县| 游戏| 通榆县| 海口市| 武山县| 三江| 金秀| 安塞县| 辽源市| 玛曲县| 泸州市| 靖西县| 景德镇市|