微服务模式之事件驱动

专业名词的中文可能不准确,参考英文名词

本篇文章主要讲述我们在微服务架构设计中常见的事件驱动,内容如下:

1.Event Stream-事件流

2.Event Sourcing-事件溯源

3.Polyglot Persistence-混合持久化

4.Command Query Responsibility Separation-命令查询分离

目前国内外互联网公司已经从单体应用(monolithic)完全转变为微服务架构(microservices)。单体架构就是把所有的功能都耦合在一个进程之中,如果要横向扩展就要把整个应用进行复制。


单体应用架构最大问题在于单一数据库。因为分布式事务以及join连接很难进行垂直或者水平扩展。当大并发访问会造成性能瓶颈。

微服务已经有很多文章谈到了,最根本的方法就是按照业务垂直进行服务拆分,每个服务都是独立的应用,分别调用独立的数据库以及独立的资源。

笔者在2014年的一个产品中进行了微服务规划及改造,具体架构如下,为了方便大家理解以服务端的视角来描述微服务架构。


每个功能都是独立的node app(可以理解为一个spring boot),每个功能都有独立的数据库(Mongodb)。每个服务都是无状态可以进行横向扩展。每个数据库都可以进行replication/sharding集群。


Event Stream

在我尝试迁移整个架构的过程中,Event Stream是我常用的方法之一。可以把一些event扔到kafka或者rabbitmq中。把一组event可以理解为topic,当然event一定要进行持久化,目前技术选择MapR stream也是不错的选择,安利一下支持kafka api。如图


一个典型的event stream

要记住的是,event一定要进行状态持久化。


Event Sourcing

Event Sourcing也是架构常见的设计模式,其实就是保存了修改记录的各个状态的步骤,如图。


我们还是采用stream的方式来记录整个事件的变化,如上图所示,在stream中,可以重新创建整个账户。其实这种是很常见的模式,比如源码管理及数据库复制都是这种模式。

这种模式带来的优势很多,如跟踪整个变化过程,数据一致性。


Polyglot Persistence

混合持久化顾名思义就是根据不同的需求应用不同的数据库,


event混合型存储


如图,根据不同的业务场景把数据的变化存储为不同的数据模型中,比如在更新一个商品的基本信息,把基本属性信息存储在关系型数据库中,把前端页面展示商品信息存储在mongodb中,为了全文搜索同步又会更新我们的Elasticsearch中,等等你能想象的业务场景。


CQRS

简而言之就是使用event sourcing把一个系统的读命令和命令请求(写请求)进行分离,我就举一个CMS的例子把,需求就是查询最新的5篇文章,传统的方式如下,


传统单体模式

CQRS模式如下


CQRS

这种架构过程就是把文章添加的event写入到了stream中,在通过consumer写入到文章展示库中,我们可以选用mongodb或者redis,都可以。CQRS本质就是把写入命令和读取通过event soucing进行分离。

总结

本篇文章主要讨论了基于event驱动的架构模式,分别讲述了Event Soucing,CQRS,Polyglot Persistence。这是微服务架构很基本的设计模式和方法,接下来也会分享更多关于微服务的文章,比如api gateway的选择等等。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352