当前位置:网站首页>Kratos微服务框架下实现CQRS架构模式
Kratos微服务框架下实现CQRS架构模式
2022-07-03 18:26:00 【Kratos开源社区】
命令查询的责任分离 Command Query Responsibility Segregation 通常被简化为 命令查询分离,即读写分离。
在特定的场景下,它可以提供更好的性能。但是,在强一致性方面,它并不能够保证。而且,还会带来认知负担。所以,实际运用上,需要谨慎。
什么是 CQRS
这个概念出自于 命令与查询分离(CQS, Command Query Separation),出自于 1987 年 Bertrand Meyer 的
命令(Command):在执行之后,会改变对象的状态。 查询(Query):仅仅是查看对象的数据,而不会对对象产生改变。
而 命令查询的责任分离 Command Query Responsibility Segregation (简称 CQRS)模式是一种架构体系模式,能够使改变模型的状态的命令和模型状态的查询实现分离。
在单体应用时代,它是读写分离:
data:image/s3,"s3://crabby-images/0a7ba/0a7ba8a42053df8265709fbcdcb5d40b7dbe5866" alt="Image"
而在微服务的时代,就变成了命令查询的责任分离:
data:image/s3,"s3://crabby-images/1c2b7/1c2b7c80597c3bffb86683d5852b1fe10d56b51d" alt="Image"
读写分离解决了什么?
数据库的读写分离就是:将数据库分为了主从库,一个主库用于写数据,多个从库完成读数据的操作,主从库之间通过某种机制进行数据的同步。
大多数互联网业务,往往读多写少。这时候,数据库的读会首先成为数据库的瓶颈。这时,如果我们希望能够线性的提升数据库的读性能,消除读写锁冲突从而提升数据库的写性能,那么就可以使用读写分离的架构:主从,主主等。
MySQL 用的最多的就是主从,主数据库通过 BinLog 同步到从数据库。这就产生了一个问题,数据不一致问题。如果写数据的压力很大,binlog 就会拥塞,从库数据更新不及时,就会读到老旧的脏数据。所以这个方案局限了它的应用范围:只有对一致性要求不高的场景才好使。比如,日志查询,报表等。
实现 CQRS
在这里讨论是物联网的时序数据的存取场景。
我们分为两个微服务:
日志查询服务(kratos.logger.service)
主要是开放了 API 用于查询数据库,获取日志数据。
日志写入服务(kratos.logger.job)
订阅 Kafka 的日志数据写入 Topic,写入到时序数据库中去。
Docker 部署开发服务器
TimeScaleDB
docker pull timescale/timescaledb:latest-pg14
docker pull timescale/timescaledb-postgis:latest-pg13
docker pull timescale/pg_prometheus:latest-pg11
docker run -itd \
--name timescale-test \
-p 5432:5432 \
-e POSTGRES_PASSWORD=123456 \
timescale/timescaledb-postgis:latest-pg13
Kafka
docker pull bitnami/kafka:latest
docker pull bitnami/zookeeper:latest
docker pull hlebalbau/kafka-manager:latest
docker run -itd \
--name zookeeper-test \
-p 2181:2181 \
-e ALLOW_ANONYMOUS_LOGIN=yes \
bitnami/zookeeper:latest
docker run -itd \
--name kafka-standalone \
--link zookeeper-test \
-p 9092:9092 \
-v /home/data/kafka:/bitnami/kafka \
-e KAFKA_BROKER_ID=1 \
-e KAFKA_LISTENERS=PLAINTEXT://:9092 \
-e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://127.0.0.1:9092 \
-e KAFKA_ZOOKEEPER_CONNECT=zookeeper-test:2181 \
-e ALLOW_PLAINTEXT_LISTENER=yes \
--user root \
bitnami/kafka:latest
docker run -itd \
-p 9000:9000 \
-e ZK_HOSTS="localhost:2181" \
hlebalbau/kafka-manager:latest
Consul
docker pull bitnami/consul:latest
docker run -itd \
--name consul-server-standalone \
-p 8300:8300 \
-p 8500:8500 \
-p 8600:8600/udp \
-e CONSUL_BIND_INTERFACE='eth0' \
-e CONSUL_AGENT_MODE=server \
-e CONSUL_ENABLE_UI=true \
-e CONSUL_BOOTSTRAP_EXPECT=1 \
-e CONSUL_CLIENT_LAN_ADDRESS=0.0.0.0 \
bitnami/consul:latest
Jaeger
docker pull jaegertracing/all-in-one:latest
docker run -d \
--name jaeger \
-e COLLECTOR_ZIPKIN_HOST_PORT=:9411 \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 14250:14250 \
-p 9411:9411 \
jaegertracing/all-in-one:latest
测试
下载工具
Postman[1] Offset Explorer[2]
进行测试
测试写
使用 Offset Explorer 模拟设备,向 Topic logger.sensor.ts
发送 JSON 数据:
[{"ts": 1646409307, "sensor_id": 1, "temperature":30, "cpu":20}]
测试读
使用 Postman 向日志服务发起 gRPC 请求进行查询。
技术栈
Kratos[3] TimeScaleDB[4] Kafka[5] Consul[6] Jaeger[7] Entgo[8]
实例代码
Kratos Examples[9]
参考资料
Postman: https://www.postman.com/downloads/
[2]Offset Explorer: https://www.kafkatool.com/download.html
[3]Kratos: https://go-kratos.dev/
[4]TimeScaleDB: https://www.timescale.com/
[5]Kafka: https://kafka.apache.org/
[6]Consul: https://www.consul.io/
[7]Jaeger: https://www.jaegertracing.io/
[8]Entgo: https://entgo.io/
[9]Kratos Examples: https://github.com/go-kratos/examples/tree/main/cqrs
[10]淺談 CQRS 的實現方法: https://medium.brobridge.com/%E6%B7%BA%E8%AB%87-cqrs-%E5%AF%A6%E7%8F%BE%E6%96%B9%E6%B3%95-3b4fcb8d5c86
[11]淺談微服務拆分原理: https://medium.brobridge.com/%E6%B7%BA%E8%AB%87%E5%BE%AE%E6%9C%8D%E5%8B%99%E6%8B%86%E5%88%86%E5%8E%9F%E7%90%86-d43fbb33e722
[12]详解 CQRS 架构模式: https://www.infoq.cn/article/wdlpjosudoga34jutys9
边栏推荐
- 网格图中递增路径的数目[dfs逆向路径+记忆dfs]
- [combinatorics] exponential generating function (concept of exponential generating function | permutation number exponential generating function = combinatorial number ordinary generating function | e
- 199. Right view of binary tree - breadth search
- [Tongxin UOS] scanner device management driver installation
- Redis core technology and practice - learning notes (VII) sentinel mechanism
- Ssl/bio of OpenSSL_ get_ fd
- Install apache+php+mysql+phpmyadmin xampp and its error resolution
- 2022-2028 global sepsis treatment drug industry research and trend analysis report
- PHP MySQL where clause
- Torch learning notes (2) -- 11 common operation modes of tensor
猜你喜欢
Three gradient descent methods and code implementation
Computer graduation design PHP makeup sales Beauty shopping mall
2022-2028 global plasmid DNA cdmo industry research and trend analysis report
Torch learning notes (3) -- univariate linear regression model (self training)
How do microservices aggregate API documents? This wave of operation is too good
English grammar_ Adjective / adverb Level 3 - multiple expression
Prototype inheritance..
2022-2028 global scar care product industry research and trend analysis report
Have you learned the correct expression posture of programmers on Valentine's day?
Class exercises
随机推荐
TypeScript 官网教程
2022-2028 global physiotherapy clinic industry research and trend analysis report
Enterprise custom form engine solution (12) -- form rule engine 2
Bloom filter [proposed by bloom in 1970; redis cache penetration solution]
[combinatorics] exponential generating function (example of exponential generating function solving multiple set arrangement)
ES7 - Optimization of promise
AcWing 271. 杨老师的照相排列【多维DP】
[combinatorics] generating function (positive integer splitting | unordered | ordered | allowed repetition | not allowed repetition | unordered not repeated splitting | unordered repeated splitting)
What problems can cross-border e-commerce sellers solve with multi platform ERP management system
模块九作业
How many convolution methods does deep learning have? (including drawings)
[combinatorics] generating function (commutative property | derivative property | integral property)
win32:堆破坏的dump文件分析
2022-2028 global marking ink industry research and trend analysis report
【统信UOS】扫描仪设备管理驱动安装
How to expand the capacity of golang slice slice
Usage of laravel conditional array in
Closure and closure function
The second largest gay dating website in the world was exposed, and the status of programmers in 2022
Data analysis is popular on the Internet, and the full version of "Introduction to data science" is free to download