- Ambassador pattern
适合多个App共享一些网络功能或者不方便修改程序加入网络功能,将网络功能放入单独的进程中
data:image/s3,"s3://crabby-images/a1bbe/a1bbeb43acd73a4ba69c9e59abef60b3e16d9085" alt=""
- Anti-Corruption Layer pattern
老系统与新系统之间加一层转换层,避免老系统污染新系统
data:image/s3,"s3://crabby-images/c4489/c4489defde40aba4ca57cd3c542cdc594f627d9f" alt=""
- Backends for Frontends pattern
为移动端或者web端搭建不同的后端,可以使不同的后端为不同的前端作优化
data:image/s3,"s3://crabby-images/56b24/56b241a7df65ea0368bff66561fb21811d7c0ddb" alt=""
- Bulkhead pattern
将client请求service的资源分组,避免一类请求消耗掉所有的资源
data:image/s3,"s3://crabby-images/2242c/2242c9482c87a968e0e7c6d69bedaac59784aced" alt=""
- Cache-Aside pattern
读数据时,如果缓存里没有,就从data store里读取,然后放入缓存
写数据时,写进data store,然后invalidate缓存的数据
data:image/s3,"s3://crabby-images/5a5b9/5a5b902f496fdc1993b9768672dff631b4960a18" alt=""
- Circuit Breaker pattern
data:image/s3,"s3://crabby-images/9a164/9a16429df3ec9fce5d51a96fa892de9b45873293" alt=""
- Command and Query Responsibility Segregation (CQRS) pattern
读取数据和写入数据的接口分开,读写数据的model也可以不同
data:image/s3,"s3://crabby-images/05274/05274108ff45b78683d47a5497500a6e4d6e115a" alt=""
- Compensating Transaction pattern
Eventual consistency is a consistency model used in distributed computing to achieve high availability that informally guarantees that, if no new updates are made to a given data item, eventually all accesses to that item will return the last updated value
为了应对Eventual consistency model中操作失败,记录每一步的操作和恢复这一步所需的操作,如果某一步失败,可以进行回滚
data:image/s3,"s3://crabby-images/0f781/0f78100ebbe57b6455c43356c737a827cee19fbb" alt=""
- Competing Consumers pattern
将耗时操作放到consumer中,通过发送message告知
data:image/s3,"s3://crabby-images/a19c6/a19c67cd0e382b696fb17ca102bf6460a9a3b302" alt=""
- Compute Resource Consolidation pattern
将类似的任务放到同一运算单元中。避免运算单元资源的浪费
data:image/s3,"s3://crabby-images/87db0/87db0605c2fa29f0928d87ba8c6644405d74b51e" alt=""
- Event Sourcing pattern
传统CRUD的缺点:
- 所有操作都在同一数据集上操作,会导致性能下降
- 数据更新操作有可能会冲突
- 没有历史数据
Event source 将对数据的操作记录到Event store中,然后通知订阅者去执行每个event对应的操作
data:image/s3,"s3://crabby-images/9f34c/9f34c610c0167ae41318c6556d8bc08aa3b13f07" alt=""
- External Configuration Store pattern
多个应用实例要共享配置信息时,配置应该单独保存在配置服务器上
data:image/s3,"s3://crabby-images/819cc/819cc8056c3188e1d993f793febd75fb9f97b42a" alt=""
- Federated Identity pattern
用户系统应该使用外部提供的服务
data:image/s3,"s3://crabby-images/be40a/be40af6d9ee9964f6594380028ccdd1d02500159" alt=""
- Gatekeeper pattern
提供公共接口的部分和访问内部资源部分要分开,提供公共接口的部分做gatekeeper
data:image/s3,"s3://crabby-images/0daf3/0daf3bcd1bd4996db62ff78d54042bea64da3281" alt=""
- Gateway Aggregation pattern
如果一个客户端要请求多个backend,可以每个请求合并成一个,改善请求性能
data:image/s3,"s3://crabby-images/59479/5947938146d885f8df487aaea9f9f81087007951" alt=""
- Gateway Offloading pattern
将一些公共的服务抽取到GateWay中,统一让gateway处理
data:image/s3,"s3://crabby-images/4fdd7/4fdd73d31fee85a2fed93c974d06fdc340c46aae" alt=""
- Gateway Routing pattern
当client需要访问多个service时,让gateway充当唯一的endpoint,由gateway将请求route到对应的service
data:image/s3,"s3://crabby-images/4c6ac/4c6ac6486a8dd1d10400535c4b43006f5326e1d8" alt=""
- Health Endpoint Monitoring pattern
服务应该提供一个endpoint供外部访问,提供自己的health check result
data:image/s3,"s3://crabby-images/0e1f9/0e1f99c14f2479099529ec712a6583aff78441d5" alt=""
- Index Table pattern
对于no sql数据库,这种不支持index的数据库,可以自己创建index table
data:image/s3,"s3://crabby-images/e0334/e0334242e358e1c0e9d6d96796d73647b6537b1c" alt=""
- Leader Election pattern
在使用分布式系统进行任务处理时,需要推选一位Leader,进行任务的协调。
- Materialized View pattern
data store中的数据可能不适合于查询,提前生成适合于查询的视图以加速查询
data:image/s3,"s3://crabby-images/c78c5/c78c50e9be8f4ba68b828a42fb5b5ce77685b16e" alt=""
- Pipes and Filters pattern
将复杂任务分解成多个可以被复用的子任务。使得每个子任务可以独立的deploy和scale
data:image/s3,"s3://crabby-images/8a98e/8a98e270cc5d7ab961eae474f0e16db4aef686d8" alt=""
- Queue-Based Load Leveling pattern
用队列作为请求和处理的缓冲,以削平请求波峰
data:image/s3,"s3://crabby-images/49938/4993814e2dacdfc8a55139454dfb24a8511414c4" alt=""
- Retry pattern
当请求服务失败时,进行重试
- 取消重试: 如果错误是不可恢复的或者重试也不太可能成功的,取消重试
- 重试: 如果是短暂或者不常见的错误,立即重试
- 一定延迟后的重试:如果是服务繁忙,则在一定延迟后重试,重试间隔要使其他重试的client均匀分布,避免使本来繁忙的server更加繁忙
- Scheduler Agent Supervisor pattern
-
Scheduler: 协调一个task中不同step的运行,将step的状态保存到state store中。
-
Agent: 执行远程服务连接
-
Supervisor:监控各个step的运行状态,执行fail的step或者整个task的恢复
data:image/s3,"s3://crabby-images/279b3/279b3f79b6473778a6bbedf49dcef83ead86804f" alt=""
网友评论