12个微服务架构模式最佳实践
微服务架构是一种软件开发技术,它将大型应用程序分解为更小的、可管理的、独立的服务。每个服务负责特定的功能,并通过明确定义的 API 与其他服务进行通信。微服务架构有助于实现软件系统更好的可扩展性、可维护性和灵活性。
接下来,我们将介绍微服务架构12种模式。
1. API 网关模式
API 网关充当所有客户端请求的统一入口点,简化了对微服务的访问,提供客户端和服务之间的无缝通信。提供安全、限流、缓存、日志、监控、认证、熔断、重试等功能。
推荐技术栈:Spring cloud gateway、Zuul
2. 服务发现模式
为什么服务发现对于微服务架构至关重要?随着系统规模的扩展,管理不断变化的服务位置变得越来越具有挑战性。通过服务发现,服务可以自动注册和发现彼此,从而提高系统的敏捷性和灵活性。
推荐技术栈:Nacos、Eureka
3. 断路器模式
为什么要实施断路器模式?在微服务生态系统中,单个故障服务可能会导致多米诺骨牌效应,扰乱依赖它的其他服务。通过使用断路器,可以隔离故障服务并防止进一步损坏,从而确保系统的弹性和稳定性。
推荐技术栈:Sentinel、Netflix Hystrix
4.负载均衡模式
引入负载平衡模式 - 在服务之间均匀分配流量、确保最佳性能并防止服务过载的关键。随着应用程序的增长,不均匀的流量分配可能会导致服务降级甚至失败。负载平衡可确保单个服务不会成为瓶颈,从而提高性能和可靠性。
负载均衡可以通过多种算法实现,例如轮询、最少连接、加权轮询等。每种算法都有其优点和用例,为系统选择正确的算法至关重要。NGINX 和 HAProxy 等工具提供强大的负载平衡解决方案,可以微调流量分配策略。
5. Bulkhead (舱壁隔离)模式
要最大限度地减少微服务架构中服务故障的影响?舱壁隔离模式就是最佳选择!这种模式隔离服务和资源,确保一项服务的故障不会导致整个系统瘫痪。
要如何实现:例如为每个服务创建专用资源,如单独的线程池或数据库连接。这样,即使一项服务耗尽其资源,其他服务也不会受到影响。
6. CQRS 模式
在传统架构中,结合读取和写入操作可能会导致性能瓶颈并增加复杂性。借助 CQRS,可以单独优化每个操作,从而提高性能并简化维护。
实施 CQRS 涉及两部分:一个用于处理命令(写入操作),另一个用于处理查询(读取操作)。这种分离为每种操作类型应用不同的扩展、缓存和数据库策略。
7. 事件驱动架构模式
事件驱动架构模式提供了一种强大的方法来增强微服务的响应能力、灵活性和可扩展性。通过利用事件驱动架构模式,可以最大限度地减少服务之间的直接依赖关系,从而提高灵活性并简化系统演进。事件驱动系统的使用场景包括实时通知、数据流和物联网应用程序等。
推荐技术栈:Apache Kafka、RabbitMQ 、RocketMQ
8. Saga 模式
在微服务架构中,事务通常跨越多个服务,这使得传统的ACID事务不适合。Saga 模式提供了一种管理这些复杂场景的方法,同时保留微服务的优势。Saga 模式为处理分布式事务提供了可靠的解决方案,确保数据一致性,同时保持服务的自主性。
推荐技术栈:Seata
9. 重试模式
为什么要采用重试模式?在微服务生态系统中,网络中断或服务超时等暂时性故障是不可避免的。重试模式使服务能够从这些问题中正常恢复,从而增强整体系统稳定性。
要实现重试模式关键在于定义合适的重试策略,包括最大重试次数、重试之间的延迟以及任何指数退避等因素。
10.BFF模式
单一后端服务可能无法满足不同前端的不同需求。BFF 模式能够为每个平台自定义后端服务,从而增强性能和用户体验。
BFF 模式是优化微服务生态系统中跨多个平台的用户体验的好方法。通过采用这种模式,就可以根据每个平台的需求定制服务,确保一流的性能和用户满意度。
11. Sidecar 模式
在微服务架构中,保持服务独立性至关重要。Sidecar 模式能够在不影响主要服务的情况下添加新功能或横切关注点,从而保持模块化和可维护性。
实现 Sidecar 模式需要在主服务容器旁边部署一个单独的容器。这个“sidecar”容器处理特定任务,例如日志记录、监控或安全性,使主要服务能够专注于其核心功能。
Sidecar 模式是扩展微服务功能同时保持其模块化和独立性的有效方法。通过采用这种模式,可以轻松增强服务,确保系统可扩展且可维护。
12. Strangler模式
要实现从单体架构到微服务的迁移,可以使用Strangler模式。Strangler 模式允许增量替换,最大限度地减少停机时间和风险,同时保持业务连续性。
要实现 Strangler 模式,首先要确定整体系统中的特定功能。然后创建一个新的微服务来处理该功能,并使用 API 网关或代理将请求重定向到新服务。随着时间的推移,便可以对其他功能重复此过程,直到整个整体被微服务取代。
相关文章:
12个微服务架构模式最佳实践
微服务架构是一种软件开发技术,它将大型应用程序分解为更小的、可管理的、独立的服务。每个服务负责特定的功能,并通过明确定义的 API 与其他服务进行通信。微服务架构有助于实现软件系统更好的可扩展性、可维护性和灵活性。 接下来,我们将介…...
快速搭建:对象存储平台MinIO
简介:MinIO 是一个高性能的对象存储服务器,兼容Amazon S3云存储服务。适用于大数据存储和用于构建私有云的场景。作为一个对象存储服务,它基于Apache License 开源协议,兼容Amazon S3云存储接口。适合存储非结构化数据,…...
Nomad 系列-Nomad+Traefik+Tailscale 集成实现零信任安全
系列文章 Nomad 系列文章Traefik 系列文章Tailscale 系列文章 概述 终于到了令人启动的环节了:NomadTraefikTailscale 集成实现零信任安全。 在这里: Nomad 负责容器调度;(容器编排工具)Traefik 负责入口流量&…...
(二十一)大数据实战——Flume数据采集之复制和多路复用案例实战
前言 本节内容我们完成Flume数据采集的一个多路复用案例,使用三台服务器,一台服务器负责采集本地日志数据,通过使用Replicating ChannelSelector选择器,将采集到的数据分发到另外俩台服务器,一台服务器将数据存储到hd…...
VM安装RedHat7虚机ens33网络不显示IP问题解决
1、今天在VMware中安装RedHat7.4虚拟机,网络连接使用的是 NAT 连接方式,刚开始安装成功之后输入ifconfig 还能看到ens33自动分配的IP地址,但是当虚机关机重启后,再查看IP发现原来的ens33网络已经没有了,只变成了这两个…...
Leetcode 第 362 场周赛题解
Leetcode 第 362 场周赛题解 Leetcode 第 362 场周赛题解题目1:2848. 与车相交的点思路代码复杂度分析 题目2:2849. 判断能否在给定时间到达单元格思路代码复杂度分析 题目3:2850. 将石头分散到网格图的最少移动次数思路代码复杂度分析 题目4…...
蓝桥杯官网练习题(0的个数)
问题描述 给定一个正整数 n ,请问 n 的十进制表示中末尾总共有几个 0 ? 输入格式 输入一行包含一个正整数 n。 输出格式 输出一个整数,表示答案。 样例输入 20220000样例输出 4评测用例规模与约定 对于所有评测用例,1 &l…...
计算线段上距离线段外某一点最近的点
一、问题 已知 p 0 = ( x 0 , y 0 ) p_0=(x_0, y_0) p...
港联证券股票分析:经济拐点显现 积极提升仓位
港联证券指出,商场底部上升的方向不变,当时稳增加和活跃资本商场的活跃方针仍在持续落地,一起也看到了一些经济数据边沿企稳的迹象,跟着方针作用的进一步闪现,商场情绪有望持续好转,上市公司基本面也有望得…...
不同的图像质量评价指标(IQA)
一、NR-IQA 这是一种方法不是指标 “Non-Reference Image Quality Assessment”(NR-IQA)是一种图像质量评价(Image Quality Assessment, IQA)方法,通常用于评估图像的质量,而无需使用参考图像(…...
linux命令-tar 命令
tar 命令 tar 命令一般用来打包文件 ,文件夹 , 方便传输使用. tar命令是在Linux和UNIX系统上用于创建、查看和提取tar归档文件的工具。它通常与gzip一起使用,以便在创建归档文件时进行压缩或解压缩。 -c: 创建归档文件 -x: 提取文件 -z: 告诉 tar 命令使用 gzip …...
selenium元素定位---ElementClickInterceptedException(元素点击交互异常)解决方法
1、异常原因 在编写ui自动化时,执行报错元素无法点击:ElementClickInterceptedException 具体报错:selenium.common.exceptions.ElementClickInterceptedException: Message: element click intercepted: Element <span class"el-c…...
05_css选择器的使用
一、css选择器的类型 1、标签选择器 用法:直接写 写标签名:标签名{} 示例: <!-- <!DOCTYPE html --> <html><head><meta charset"utf-8"><title>标签选择器</title><style type"te…...
跨平台游戏引擎 Axmol-2.0.0 正式发布
下载 https://github.com/axmolengine/axmol/releases/tag/v2.0.0 更新日志 添加实验性的 WebAssembly 构建支持(WebGL 2.0),由 nowasm 贡献 已知问题 WebGL context lost 尚未处理 部署在 github pages 的 demo 可快速预览,注意:由于 Git…...
面试总结归纳
面试总结 注:循序渐进,由点到面,从技术点的理解到项目中的使用, 要让面试官知道,我所知道的要比面试官更多 一、Mybatis 为ORM半持久层框架,它封装了JDBC,开发时只需要关注sql语句就可以了…...
【刷题篇】贪心算法(一)
文章目录 分割平衡字符串买卖股票的最佳时机Ⅱ跳跃游戏钱币找零 分割平衡字符串 class Solution { public:int balancedStringSplit(string s) {int lens.size();int cnt0;int balance0;for(int i0;i<len;i){if(s[i]R){balance--;}else{balance;}if(balance0){cnt;}}return …...
从维基百科通过关键字爬取指定文本内容
通过输入搜索的关键字,和搜索页数范围,爬出指定文本内内容并存入到txt文档。代码逐行讲解。 使用re、res、BeautifulSoup包读取,代码已测,可以运行。txt文档内容不乱码。 import re import requests from bs4 import BeautifulS…...
pytorch代码实现之SAConv卷积
SAConv卷积 SAConv卷积模块是一种精度更高、速度更快的“即插即用”卷积,目前很多方法被提出用于降低模型冗余、加速模型推理速度,然而这些方法往往关注于消除不重要的滤波器或构建高效计算单元,反而忽略了特征内部的模式冗余。 原文地址&am…...
一文解析-通过实例讲解 Linux 内存泄漏检测方法
一、mtrace分析内存泄露 mtrace(memory trace),是 GNU Glibc 自带的内存问题检测工具,它可以用来协助定位内存泄露问题。它的实现源码在glibc源码的malloc目录下,其基本设计原理为设计一个函数 void mtrace ()&#x…...
Spring Boot常用的参数验证技巧和使用方法
简介 Spring Boot是一个使用Java编写的开源框架,用于快速构建基于Spring的应用程序。在实际开发中,经常需要对输入参数进行验证,以确保数据的完整性和准确性。Spring Boot提供了多种方式来进行参数验证,并且可以很方便地集成到应…...
手机+卫星的科技狂想
最近硬件圈最火热的话题之一,应该就是突然上线、遥遥领先的华为Mate 60 Pro了。 其中,CPU和类5G网速是怎么实现的,是大家特别关注的问题。相比之下,卫星通话这个功能,讨论度就略低一些(没有说不火的意思&am…...
便捷查询中通快递,详细物流信息轻松获取
在如今快节奏的生活中,快递已成为人们生活中不可或缺的一部分。然而,快递查询却常常让人头疼,因为需要分别在不同的快递公司官网上进行查询,耗费时间和精力。为了解决这个问题,固乔科技推出了一款便捷的快递查询助手&a…...
ARM接口编程—Interrupt(exynos 4412平台)
CPU与硬件的交互方式 轮询 CPU执行程序时不断地询问硬件是否需要其服务,若需要则给予其服务,若不需要一段时间后再次询问,周而复始中断 CPU执行程序时若硬件需要其服务,对应的硬件给CPU发送中断信号,CPU接收到中断信号…...
适用于Linux的Windows子系统(PHP搭建lmap、redis、swoole环境)
目录 前言 一、Windows安装Linux子系统 二、Ubuntu搭建PHP开发环境 1.PHP 安装 2.Apache2 安装 3.MySQL安装 4.Redis安装 5.Swoole安装 总结 前言 系列分为三章(从安装到项目使用): 一、适用于Linux的Windows子系统(系统安装步骤…...
Vue3+Ts+Vite项目(第十二篇)——echarts安装与使用,vue3项目echarts组件封装
概述 技术栈:Vue3 Ts Vite Echarts 简介: 图文详解,教你如何在Vue3项目中引入Echarts,封装Echarts组件,并实现常用Echarts图例 文章目录 概述一、先看效果1.1 静态效果1.2 动态效果 二、话不多数,引入 …...
hive location更新hive元数据表详解
1.hive location更新方式 一、通过修改表DDL: alter table table_name set location hdfs://nm:8020/table_path 二、直接修改hive 的meta info: update DBS set DB_LOCATION_URI replace(DB_LOCATION_URI,"oldpath","newpath")update SDS…...
【SpringBoot】统一功能处理
目录 🎃1 拦截器 🎀1.1 拦截器的代码实现 🎨1.2 拦截器的实现原理 🧶2 拦截器应用——登录验证 🦺3 异常统一处理 🎭4 统一数据返回格式 🧤4.1 为什么需要统一数据返回格式 🧣4.2 统…...
分布式数据库-架构真题(二十六)
构件组装成软件系统的过程分为三个不同的层次()。(2018年) 初始化、互连和集成连接、集成和演化定制、集成和扩展集成、扩展和演化 答案:C (2018年)CORBA服务端构件模型中,&#x…...
MyWebServer开发日记-socket
打算把 tinyWebServer 重写成跨平台(Windows and Linux)的。 这里首先需要跨平台的 sokcet,主要参考 尹圣雨 的 TCP/IP 网络编程 来着: 代码写的有些笨,欢迎批评: 首先是一个 socket 类,主要…...
图书管理信息系统分析与设计
一、系统开发的可行性分析 (一)系统背景.必要性及意义 随着社会经济的迅速发展和科学技术的全面进步,计算机事业的飞速发展,以计算机与通信技术为基础的信息系统正处于蓬勃发展的时期。随着经济文化水平的显著提高,人…...
做视频可以赚钱的网站/广告策划书
MySQL存储引擎分类及操作介绍发布时间:2020-06-01 15:12:52来源:51CTO阅读:133作者:三月不知道大家之前对类似MySQL存储引擎分类及操作的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分…...
wordpress设置固定链接后/线下营销推广方式都有哪些
一、前言 今天是三月八号,祝各位女神节日快乐,虽然看到可能都是大老爷们,言归正传一月二十二号,在外地工作的我,准备从上海回到湖北老家,前几天就听同事说当时肺炎有点严重,但是当时其实并没有…...
拖拽建站平台/什么平台可以免费打广告
七、招生问答1、上课时间怎么安排?答:因为我们是一对一上课。所以,上课时间是由您自己来安排,您什么有空,就什么时候来学习。2、我很笨,学不会怎么办?答:其实人与人之间,…...
共青城市建设局网站/网络广告发布
简介 这节课我们将讨论如何在OSG中使用键盘和灯光。我们将会学习指定三种纹理过滤方式,学习如何使用键盘来移动场景中的立方体。 在osg中通过osgGA库来实现与用户的交互,在用户端,通常使用GUIEventAdapter类作为系统交互事件和OSG交互事件的…...
找建筑网站/互联网推广好做吗
传送门...
建立网站不公开/免费个人网站源码
设计模式6大原则-单一职责原则 定义:一个类应该只有一个引起变化的原因。一个类只负责一项职责 如果一个类有多个职责,这些职责耦合在一起,当一个职责发生变化时,可能影响其他的职责。 如: 一个类有 A、B、C 等职责…...