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

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

相关文章

关于DNS域名解析服务

《关于DNS域名解析服务》:本文主要介绍关于DNS域名解析服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录DNS系统的作用及类型DNS使用的协议及端口号DNS系统的分布式数据结构DNS的分布式互联网解析库域名体系结构两种查询方式DNS服务器类型统计构建DNS域

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

Qt如何实现文本编辑器光标高亮技术

《Qt如何实现文本编辑器光标高亮技术》这篇文章主要为大家详细介绍了Qt如何实现文本编辑器光标高亮技术,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录实现代码函数作用概述代码详解 + 注释使用 QTextEdit 的高亮技术(重点)总结用到的关键技术点应用场景举例示例优化建议

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、