博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CQRS
阅读量:6692 次
发布时间:2019-06-25

本文共 1164 字,大约阅读时间需要 3 分钟。

hot3.png

对于复杂的系统来说,上面的做法做确实很不错。但是对于一个简单地系统来说,这样做是不是玩过火了?如果我们要设计一个博客系统的话,那么我们是不是可以考虑将Write/Read分离就可以了?

命令和查询责任分离Command Query Responsibility Segregation(CQRS)是一种将系统的读写操作分离为两种独立模型的架构模式。

CQS

对于这个架构的深入思考是起源于之前在理解DDD。据说在DDD领域中被广泛使用。理解CQRS可以用分离Model和API集合来处理读取和写入请求开始,即CQS(Command Query Separation,命令查询分离)模式。CQS模式最早由软件大师Bertrand Meyer(Eiffel语言之父,面向对象开-闭原则 OCP 提出者)提出。他认为,对象的行为仅有两种:命令和查询。

这个类型的架构如下图所示:

CQS BasicCQS Basic

除了编写优化的查询类型,它可以让我们轻松换API的一部分读一些缓存机制,甚至移动读取API的请求到另一台服务器。

对于读取和写入相差不多的应用来说,这种架构看起来还是不错的。而这种架构还存在一个瓶颈问题,使用同一个RDBMS。对于写入多、读取少的应用来说,这种架构还是存在着不合理性。

为了解决这个问题,人们自然是使用缓存来解决这个问题了。我们在我们的应用服务外有一个HTTP服务器,而在HTTP服务器之外有一个缓存服务器,用于缓存用户常驻的一些资源。如下图所示:

带缓存的Web架构带缓存的Web架构

而实际上这样的服务器可能是多余的——我们为什么不直接生成HTML就好了?

编辑-发布分离

或许你听过Martin Folwer提出的编辑-发布分享式架构:即文章在编辑时是一个形式,而发表时是另一个形式,比如用markdown编辑,而用html发表。

编辑-发布分离编辑-发布分离

而最典型的应用就是流行于GitHub的Hexo、Jekyll框架之类的静态网站。如下图所示的是Hexo的工作流:

Hexo站点工作流Hexo站点工作流

我们在本地生成我们的项目,然后可以创建一个新的博客、开始编写内容等等。接着,我们可以在本地运行起这个服务,除了查看博客的内容,还可以修改样式等等。完成上面的工作后,我们就可以生成静态内容,然后部署我们的应用到GitHub Page上。这一切看上去都完美。

但是作为一个前端开发人员,没有JSON,用不了Ajax请求,我怎么把我的博客做成一个单页面应用?

编辑-发布-开发分离

基于git的编辑-发布分离基于git的编辑-发布分离

对于有大量数据的网站怎么办?Scrapy爬虫

CQRS 进阶

CQRS进阶CQRS进阶

高级CQRS

六边形架构

Nginx微服务

Nginx解耦微服务Nginx解耦微服务

转载于:https://my.oschina.net/lilugirl2005/blog/650666

你可能感兴趣的文章
OpenStack icehouse系列之问题处理
查看>>
从硬盘安装OracleLinux6.3之软驱故障
查看>>
【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记41 Animation动画
查看>>
Nero 宣布在Linux上支持蓝光和HD-DVD的烧录
查看>>
Web Interface登陆界面优化
查看>>
Win7项目分享part1:Windows7准备的3个阶段
查看>>
Yeslab安全实验室教徒计划第二期 2011-11-7
查看>>
Silverlight已支持Linux,Moonlight 1.0正式版发布(附下载地址)
查看>>
Android API 中文 (53) —— BaseAdapter
查看>>
VMware安装失败 “Failed to create the requested registry key Key:installer Error:1021"
查看>>
新瓶旧酒ASP.NET AJAX(5) - 客户端脚本编程(Sys.UI命名空间下的类和快捷方法)
查看>>
apt成熟度模型
查看>>
SQL Server 2014 日志传送部署(7):日志传送故障转移和删除日志传送
查看>>
SQL Server 2014(正式发行版)安装指南
查看>>
Unix下的nfs渗透技术
查看>>
SQL Server 2016 配置链接服务器及数据还原
查看>>
细分市场能否改变IM软件寡头统治的现状?
查看>>
通过jquery做密码框的显示和隐藏效果
查看>>
Hadoop Map-Reduce的压缩最终输出文件
查看>>
译码阻塞和死锁的等待资源
查看>>