HarmonyOS开发者限时福利来啦!最高10w+现金激励等你拿~ 了解详情
写点什么

数据是实现微服务的难点

  • 2016-09-04
  • 本文字数:996 字

    阅读完需:约 3 分钟

企业在创建和开发微服务的过程中,最困难的问题之一就是他们的数据。如果我们采用领域驱动设计(Domain-Driven Design,DDD)来分析业务领域并剖析数据所代表的含义,将会有助于实现微服务架构 Christian Posta 在一个关于微服务实现的系列博客文章中阐述了该理念。

Posta 是 Red Hat 的中间件主架构师,对于他来说,选择微服务架构的主要原因在于这种架构能够让负责系统不同组成部分的团队按照不同的进度来开展工作,并且能够让他们之间的相互干扰达到最小。当按照这种方式来组织团队的时候,系统架构能够反映出这种变化,并且会向微服务架构来演化。

但是,如何让团队之间的这种自治真正运转起来,这一点其实并不简单。在单体架构中,通常会使用事务并且只有一个数据库,如果每个服务都具有一个数据库,那么这会变成一项挑战,对于传统的企业来讲更是如此。

Posta 指出,在实现微服务方面,互联网公司和传统企业之间有着巨大的差异。互联网公司采用微服务的目的主要是解决大量数据和扩展性的问题,而传统企业要同时处理业务和扩展性方面的复杂性。播放影片或发送推文的复杂性要远远低于保险索赔系统的复杂性。

在为相对复杂的企业域构建微服务时,我们需要找到在这个域中不同责任的边界。在每个边界中,我们会创建领域模型,这个模型是针对业务责任所设计的,并反映了这种业务责任。针对每个边界的数据模型会由同一个边界中的领域模型来驱动。采用 DDD 的方式我们能够找到这些边界,并会为每个边界创建一个有界上下文(bounded context),每个上下文将会成为一个微服务。

在Posta 的经验中,开发人员在构建分布式系统时,会倾向于假设只有一个关系型数据库,并试图将网络的不稳定性抽象出来。跨多个服务所带来的分布式数据问题通常会通过二阶段提交来解决。与这种做法不同,Posta 相信,我们必须要寻找每个有界上下文中的事务性边界,并找到满足业务限制和不变量的最小原子单元,不要让事务传播到其他的上下文之中。

我们还需要有一种机制,能够让服务通知其他的服务发生了什么,针对这种需求,Posta 推荐使用事件。我们的服务会发布事件,描述在这个域中发生了什么,其他的服务会读取这些事件,调整它们自己的模型并将变更进行持久化。

关于这些理念的更深入描述,Posta 引用了Vaughn Vernon 发布的一系列博客文章,这些文章基于DDD 理念,描述了聚集、事务边界和有界上下文。

查看英文原文 Data is the Hard Part Working with Microservices

2016-09-04 19:002833

评论

发布
暂无评论
发现更多内容

Elasticsearch源码解析:环境搭建

Jackey

elasticsearch

Apache下error.log文件太大的处理方法

一直AC一直爽

轻松应对并发问题,简易的火车票售票系统,Newbe.Claptrap 框架用例,第一步 —— 业务分析

newbe36524

容器 微服务 架构设计 .net core ASP.NET Core

最短路径问题(无负边值)——Dijkstra算法

烫烫烫个喵啊

算法 prim 最短路径

我有一个梦想

一直AC一直爽

随笔杂谈 梦想

剪刀爱情

一直AC一直爽

电影

布隆过滤器是个啥!

诸葛小猿

布隆过滤器 bloomfilter bloom filter

排序笔记

烫烫烫个喵啊

算法 排序

总结:PHP值得注意的几个问题

一直AC一直爽

php

技术面试官应该怎么问?面试者应该怎么答?

xcbeyond

面试 自我介绍

我向面试官讲解了单例模式,他对我竖起了大拇指

苹果看辽宁体育

设计模式 单例模式

爸爸,我想握住你的手

一直AC一直爽

随笔杂谈 父爱

HashiCorp官宣:禁止国内使用其旗下Consul等开源软件?

xcbeyond

Consul 条款

公开课 | 吉祥人寿从0到1的 Jira 落地实践

Atlassian

敏捷开发 研发管理 Jira

week7 学习总结

Geek_2e7dd7

广义表的实现!

烫烫烫个喵啊

算法 广义表

读《我的大学,我的苦难》有感

一直AC一直爽

随笔杂谈 读后感

第七周总结

andy

极客大学

redis系列之——缓存穿透、缓存击穿、缓存雪崩

诸葛小猿

redis 缓存穿透 缓存击穿 缓存雪崩

可读代码编写炸鸡九 - 抽取子问题

多选参数

编程 代码 代码优化 代码规范 可读代码

ZK 从入门到放弃 入门篇

小隐乐乐

Mysql错误:Ignoring query to other database解决方法

一直AC一直爽

MySQL

架构师是怎样炼成的 7-1 性能测试与优化

闷骚程序员

百度CTO王海峰对话王辰院士:全球“最强大脑”助力大数据抗疫时代来临

脑极体

寻找感动的养分

一直AC一直爽

感恩 随笔杂谈 感动

week7 作业

Geek_2e7dd7

架构师训练营 -- 第七周作业

stardust20

Redis(二)单机版安装

奈何花开

Java redis

手把手教你写数独计算器(1)

一直AC一直爽

c++ 算法 数独

思维模型盲区:所知障和从众效应

石云升

思维模型 倾听 从众效应

性能测试

陈皮

数据是实现微服务的难点_语言 & 开发_Jan Stenberg_InfoQ精选文章