微服务架构体系,架构图,技术栈,服务体系

2023-10-22 03:59

本文主要是介绍微服务架构体系,架构图,技术栈,服务体系,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.什么是微服务

微服务是一种架构风格,其他如:MVC架构风格。它有六个特点

  1. 一组的服务
  2. 独立的进程
  3. 轻量级通信:http,json
  4. 基于业务能力:基于业务能力去构建,如商品服务,用户服务
  5. 独立部署:可以独立部署运行
  6. 无集中式管理:原理的架构是有统一的管理,如统一的数据库,统一的消息队列等。但是微服务中可以选用自己独立的技术栈。

它具有松散耦合,面向服务(还是一种SOA),有自己的数据源(数据库)。

2.微服务的利和弊

优点:

  1. 强模块化边界:一个服务就是一个模块,可以独立部署,其他服务可以调用,边界清晰。
  2. 可独立部署:每个服务独立开发部署
  3. 技术多样性:每个服务可以选用自己的技术栈。 如用户服务用C++,商品服务用Java

缺点:

  1. 分布式复杂性:服务会有很多,一般的开发人员不知道全部的服务流程
  2. 最终一致性:每一服务都有自己的数据源, 数据源有可能不一样,如用户服务的购买订单,商品服务的被购买清单。一个服务的数据要同步到其他类似服务的数据库中。
  3. 运维复杂性:很多服务需要同时运行管理。
  4. 测试复杂性:测试时,需要调用不同的微服务程序。进行集成测试时复杂。

3.康威法则

微服务架构对应公司的组织架构

4.微服务中台战略

大中台,轻前台。

5.服务分层

6.微服务的技术架构服务体系

7. 服务发现机制

  1. 服务提供方使用注册的方式,自动注册到注册器,定期发送心跳
  2. 服务消费者从注册器中拿到提供者信息,然后负载均衡去调用服务提供方。

8.API网关

微服务都是通过接口来调用,1.为了安全过滤用户的调用,2.内部服务对用户透明。提供统一的接口。

网关的功能

  1. 反向路由:外面的请求转换为内部服务的调用
  2. 认证安全
  3. 限流熔断
  4. 日志监控

如:zuul

9.配置中心

携程的一个配置中心

​ 携程的一个配置中心

对配置进行统一管理,可进行配置的有:连接字符串(数据库连接),动态参数(超时配置,限流),业务的开关,

10.通讯方式RPC/REST

11.微服务管理和治理

12.监控分层和架构

检测错误时,从上到下依次查看错误。

使用kafka来监控

13.调用链监控

使用traceid来表示同一次调用

14.容错限流熔断

  • 熔断:出问题,进行熔断
  • 隔离:对服务进行隔离
  • 限流:对请求进行限流
  • 降级:系统无法提供能力的时候,进行降级。

15.容器部署/持续化交付

  1. 容器保证了环境一致性
  2. 通过镜像快速部署

蓝绿部署:

灰度部署:渐进地切换

16.容器集群调度和容器的发布体系

k8s

此文章为学习极客时间的微服务20讲所的。

这篇关于微服务架构体系,架构图,技术栈,服务体系的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/258930

相关文章

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

Python中高级文本模式匹配与查找技术指南

《Python中高级文本模式匹配与查找技术指南》文本处理是编程世界的永恒主题,而模式匹配则是文本处理的基石,本文将深度剖析PythonCookbook中的核心匹配技术,并结合实际工程案例展示其应用,希... 目录引言一、基础工具:字符串方法与序列匹配二、正则表达式:模式匹配的瑞士军刀2.1 re模块核心AP

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三