本文主要是介绍微服务架构体系,架构图,技术栈,服务体系,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.什么是微服务
微服务是一种架构风格,其他如:MVC架构风格。它有六个特点
- 一组小的服务
- 独立的进程
- 轻量级通信:http,json
- 基于业务能力:基于业务能力去构建,如商品服务,用户服务
- 独立部署:可以独立部署运行
- 无集中式管理:原理的架构是有统一的管理,如统一的数据库,统一的消息队列等。但是微服务中可以选用自己独立的技术栈。
它具有松散耦合,面向服务(还是一种SOA),有自己的数据源(数据库)。
2.微服务的利和弊
优点:
- 强模块化边界:一个服务就是一个模块,可以独立部署,其他服务可以调用,边界清晰。
- 可独立部署:每个服务独立开发部署
- 技术多样性:每个服务可以选用自己的技术栈。 如用户服务用C++,商品服务用Java
缺点:
- 分布式复杂性:服务会有很多,一般的开发人员不知道全部的服务流程
- 最终一致性:每一服务都有自己的数据源, 数据源有可能不一样,如用户服务的购买订单,商品服务的被购买清单。一个服务的数据要同步到其他类似服务的数据库中。
- 运维复杂性:很多服务需要同时运行管理。
- 测试复杂性:测试时,需要调用不同的微服务程序。进行集成测试时复杂。
3.康威法则
微服务架构对应公司的组织架构
4.微服务中台战略
大中台,轻前台。
5.服务分层
6.微服务的技术架构服务体系
7. 服务发现机制
- 服务提供方使用注册的方式,自动注册到注册器,定期发送心跳
- 服务消费者从注册器中拿到提供者信息,然后负载均衡去调用服务提供方。
8.API网关
微服务都是通过接口来调用,1.为了安全过滤用户的调用,2.内部服务对用户透明。提供统一的接口。
网关的功能
- 反向路由:外面的请求转换为内部服务的调用
- 认证安全
- 限流熔断
- 日志监控
如:zuul
9.配置中心
携程的一个配置中心
对配置进行统一管理,可进行配置的有:连接字符串(数据库连接),动态参数(超时配置,限流),业务的开关,
10.通讯方式RPC/REST
11.微服务管理和治理
12.监控分层和架构
检测错误时,从上到下依次查看错误。
使用kafka来监控
13.调用链监控
使用traceid来表示同一次调用
14.容错限流熔断
- 熔断:出问题,进行熔断
- 隔离:对服务进行隔离
- 限流:对请求进行限流
- 降级:系统无法提供能力的时候,进行降级。
15.容器部署/持续化交付
- 容器保证了环境一致性
- 通过镜像快速部署
蓝绿部署:
灰度部署:渐进地切换
16.容器集群调度和容器的发布体系
k8s
此文章为学习极客时间的微服务20讲所的。
这篇关于微服务架构体系,架构图,技术栈,服务体系的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!