认识微服务、服务拆分和远程调用

2023-09-18 15:11:56

1.认识微服务
  • 单体架构: 将业务的所有功能集中在一个项目中开发,打成一个包部署
  • 分布式架构: 根据业务功能对系统做拆分,每个业务功能模块作为独立项目开发,称为一个服务
架构优点缺点
单体架构架构简单,部署成本低,耦合度高(维护困难、升级困难)
分布式架构降低服务耦合,有利于服务升级和拓展服务调用关系错综复杂
2.微服务架构的特征
  • 单一职责: 微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责
  • 自治: 团队独立、技术独立、数据独立,独立部署和交付
  • 面向服务: 服务提供统一标准的接口,与语言和技术无关
  • 隔离性强: 服务调用做好隔离、容错、降级,避免出现级联问题
3. SpringCloud
  • SpringCloud是微服务架构的一站式解决方案,集成了各种优秀微服务功能组件
  • Spring Cloud 为开发人员提供了在分布式系统中快速构建一些常见模式的工具(例如配置管理、服务发现、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态)。分布式系统的协调导致了样板模式,使用 Spring Cloud 开发人员可以快速建立实现这些模式的服务和应用程序。它们可以在任何分布式环境中很好地工作,包括开发人员自己的笔记本电脑、裸机数据中心和托管平台
4.服务拆分
  • 原则

    • 不同微服务,不要重复开发相同业务
    • 微服务数据独立,不要访问其它微服务的数据库
    • 微服务可以将自己的业务暴露为接口,供其它微服务调用
  • 拆分时机

    • 有快速迭代的需求
    • 提交代码频繁出现大量冲突
    • 小功能要积累到大版本才能上线
    • 解决高并发横向扩展问题
  • 拆分原则

    • 单一职责原则: 每个微服务只需关心自己的业务规则,确保职责单一,避免职责交叉,耦合度过高将会造成代码修改重合,不利于后期维护。
    • 服务自治原则: 每个微服务的开发,必须拥有开发、测试、运维、部署等整个过程,并且拥有自己独立的数据库等,可以完全把其当作一个单独的项目来做,而不牵扯到其他无关业务。
    • 轻量级通信原则: 微服务间需通过轻量级通信机制进行交互。首先是体量较轻,其次是需要支持跨平台、跨语言的通信协议,再次是需要具备操作性强、易于测试等能力,如:REST通信协议。
    • 接口明确原则: 明确接口要实现的内容,避免接口依赖,如A接口的改动会导致B接口的改动。
    • 持续演进原则: 单体架构向微服务架构拆分过程中,无法做到一蹴而就,刚开始不建议拆分太小,过度拆分将会带来架构复杂度的急剧升高,开发、测试、运维等环节很难快速适应,将会导致故障率大幅增加,可用性降低,非必要情况,应逐步拆分细化,持续演进,避免微服务数量的瞬间爆炸性增长。
  • 拆分方法

    微服务的拆分应遵循上述拆分时机、拆分原则,并选择合适的拆分方法,逐步拆分,还要从实际业务领域出发,并结合考虑非业务的因素,比如需求变更的频率、高性能、安全性、团队规模以及技术异构等因素

    • 业务领域拆分
    • 需求变化频率
    • 服务性能要求
    • 组织架构和团队规模
    • 安全边界
    • 技术异构
5.远程调用
  1. 注册RestTemplate,在order-service服务中的OrderApplication启动类中,注册RestTemplate实例
@MapperScan("cn.pj.order.mapper")
@SpringBootApplication
public class OrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(OrderApplication.class, args);
    }

    /**
     * 创建 RestTemplate 并注入 Spring 容器
     * @return
     */
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

}
  1. 实现远程调用
@Service
public class OrderService {

    @Autowired
    private OrderMapper orderMapper;

    @Autowired
    private RestTemplate restTemplate;

    public Order queryOrderById(Long orderId) {
        // 1.查询订单
        Order order = orderMapper.findById(orderId);

        //2.利用 RestTemplate 发起 http 请求,查询用户
        //2.1 url路径
        String url ="http://localhost:8081/user/"+order.getUserId();

        //2.2 发起 http 请求,实现远程调用
        User user=  restTemplate.getForObject(url, User.class);

        //3. 封装 user 到 Order
        order.setUser(user);

        // 4.返回
        return order;
    }
}
6.提供者与消费者
  • 服务提供者: 一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)

  • 服务消费者: 一次业务中,调用其它微服务的服务。(调用其它微服务提供的接口)
    在这里插入图片描述

  • 对于A调用B的业务而言:A是服务消费者,B是服务提供者

  • 对于B调用C的业务而言:B是服务消费者,C是服务提供者

​ 因此,服务B既可以是服务提供者,也可以是服务消费者

更多推荐

【PyTorch攻略(1/7)】 张量基本语法

一、说明Tensor是一种特殊的数据结构,与数组和矩阵非常相似。在PyTorch中,我们使用张量对模型的输入和输出以及模型的参数进行编码。张量类似于NumPy和ndarray,除了张量可以在GPU或其他硬件加速器上运行。事实上,张量和NumPy数组通常可以共享相同的底层内存地址,具有称为桥接到np标签的功能,这消除了复

VR全景展示的功能有哪些?你了解多少?

VR全景展示作为一种全新的视觉体验技术,能够为人们带来强烈的视觉效果以及沉浸式的观感,在旅游、房地产、车展、博物馆等都有着十分广泛的应用。这种富媒体技术,具有很好的交互性和沉浸感,能够带给大家更好的体验,那么VR全景展示的功能有哪些呢?1、沉浸式交互体验VR全景展示为观众提供了更加真实、更加具有沉浸式的体验,以720°

技术贴 | 深度解析 PostgreSQL Protocol v3.0(二)— 扩展查询

引言PostgreSQL使用基于消息的协议在前端(客户端)和后端(服务器)之间进行通信。该协议通过TCP/IP和Unix域套接字支持。《深度解析PostgreSQLProtocolv3.0》系列技术贴,将带大家深度了解PostgreSQLProtocolv3.0(在PostgreSQL7.4及更高版本中实现,有关早期协

Greenplum实用工具-gpfdist

注:本文翻译自https://docs.vmware.com/en/VMware-Greenplum/7/greenplum-database/utility_guide-ref-gpfdist.html向Greenplum数据库段提供数据文件或从数据库段写入数据文件。语法gpfdist[-d<directory>][

爬虫 — 字体反爬

目录一、安装字体软件FontCreator二、百度智能云文字识别三、案例一四、案例二五、案例三六、安装Tesseract1、安装步骤2、配置环境3、使用Python识别图片信息七、案例四一、安装字体软件FontCreator点击下载字体软件FontCreator安装包1、同意协议,点击Next;2、更改存放位置,点击N

CPP-Templates-2nd--第十九章 萃取的实现 19.7---

目录19.7其它的萃取技术19.7.1If-Then-Else19.7.2探测不抛出异常的操作19.7.3萃取的便捷性(TraitsConvenience)别名模板和萃取(AliasTemplatesAndTraits)变量模板和萃取(VariableTemplatesandTraits)19.8类型分类(TypeCl

第一章:最新版零基础学习 PYTHON 教程(第二节 - Python语言优势及应用)

Python是一种高级、解释型、通用动态编程语言,注重代码的可读性。与Java和C相比,它的程序通常较小。它由开发人员GuidoVanRossum于1991年创立。Python跻身世界上最流行、增长最快的语言之列。Python是一种强大、灵活且易于使用的语言。此外,Python社区也非常活跃。它被许多组织使用,因为它支

【漏洞复现】广联达OA漏洞合集(信息泄露+SQL注入+文件上传)

文章目录声明广联达OA存在信息泄露一、漏洞概述二、漏洞复现三、修复建议广联达Linkworks办公OASQL注入漏洞+后台文件上传漏洞一、产品简介二、漏洞概述三、复现环境四、修复建议声明请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,

做影视特效本地电脑配置不够怎么办?

影视特效对电脑要求高,往往本地电脑配置不足的情况下,会导致电脑卡顿等造成工作效率低下等问题,再加上现在异地协同的云电脑需求越来越高,更多的企业和个人开始选择做影视特效的云电脑,那么今天就来看看租一台云电脑如何来完成影视制作吧。在当今的影视特效行业中,技术的进步以及计算机硬件和软件的迅速发展,使得制作过程更加高效、便捷。

基于STM32+华为云IOT设计的智能垃圾桶

一、项目介绍在商业街、小吃街和景区等人流密集的场所,垃圾桶的及时清理对于提供良好的游客体验至关重要。然而,传统的垃圾桶清理方式通常是定时或定期进行,无法根据实际情况进行及时响应,导致垃圾桶溢满,影响环境卫生,给游客带来不便和不满。为了解决这一问题,本项目基于STM32F103ZET6主控芯片和华为云物联网平台,设计了一

抱歉,在座的都不会“自己介绍”!

作者|磊哥来源|公众号:Java中文社群转载请联系授权(微信ID:GG_Stone)细节决定成败,面试本质上是“自我推销”的过程。如何在短短的几十分钟内打动面试官,从来都不是一个简单的问题。所以怎么开场?怎么让面试官对我产生兴趣?非常关键。所以,接下来,我们就来聊聊,如何进行自我介绍?如果一开场就让面试官对你印象深刻。

热文推荐