SpringCloud---认识微服务,服务之间进行远程调用

认识微服务

单体架构

单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署。
在这里插入图片描述

  • 优点:架构简单,部署成本低
  • 缺点:耦合度高(维护困难、升级困难)

分布式架构

分布式架构:根据业务功能对系统做拆分,每个业务功能模块作为独立项目开发,称为一个服务。
在这里插入图片描述

  • 优点:降低服务耦合,有利于服务升级和拓展
  • 缺点:服务调用关系错综复杂

分布式架构虽然降低了服务耦合,但是服务拆分时也有很多问题需要思考:

服务拆分的粒度如何界定?
服务之间如何调用?
服务的调用关系如何管理?

微服务

微服务的架构特征:

  • 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责
  • 自治:团队独立、技术独立、数据独立,独立部署和交付
  • 面向服务:服务提供统一标准的接口,与语言和技术无关
  • 隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题
    在这里插入图片描述
    微服务的上述特性其实是在给分布式架构制定一个标准,进一步降低服务之间的耦合度,提供服务的独立性和灵活性。做到高内聚,低耦合。

因此,可以认为微服务是一种经过良好架构设计的分布式架构方案

不同微服务的技术对比:
在这里插入图片描述
市场中不同微服务之间结合使用:
在这里插入图片描述

SpringCloud

SpringCloud 是目前国内使用最广泛的微服务框架。官网地址:https://spring.io/projects/spring-cloud。

SpringCloud 集成了各种微服务功能组件,并基于 SpringBoot 实现了这些组件的自动装配,从而提供了良好的开箱即用体验。

其中常见的组件包括:
在这里插入图片描述
SpringCloud 底层是依赖于 SpringBoot 的,并且有版本的兼容关系,所以在使用时,有些组件不需要导入版本信息

微服务的大致路线:

在这里插入图片描述

服务拆分:

案例:
现在有四个模块,查询订单信息中的用户信息
在这里插入图片描述
不使用服务拆分的思路是:

通过查询订单模块中的用户id,来查询用户信息,这里订单模块中出现了查询用户信息,不同服务之间访问了其他服务的数据库,重复了业务。

使用服务拆分:

查询订单模块时,如果想要查询用户信息,可以将不同的服务模块暴露成接口,如果订单模块想要用户信息,那么就只能像用户功能发起请求才能访问,这样就将不同的业务拆分

服务拆分注意事项:

  • 单一职责:不同微服务,不要重复开发相同业务
  • 数据独立:不要访问其它微服务的数据库
  • 面向服务:将自己的业务暴露为接口,供其它微服务调用

示例:
项目结构:
在这里插入图片描述
微服务项目下,打开 idea 中的 Service,可以很方便的启动。
在这里插入图片描述
启动完成后,访问 http://localhost:8080/order/101
在这里插入图片描述
发现user信息访问不到这时就需要我们修改代码,进行远程调用

远程调用

订单服务如果需要查询用户信息,只能调用用户服务的 Restful 接口,不能查询用户数据库

因此我们需要知道 Java 如何去发送 http 请求,Spring 提供了一个 RestTemplate 工具,只需要把它创建出来即可。(即注入 Bean)
在orderservice服务启动项中编写

/**
 * Spring提供的,发送http请求的方法
 * 创建RestTemplate并注入Spring容器
 * LoadBalanced,使用的User服务做负载均衡处理
 */
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
    return new RestTemplate();
}

修改orderservice服务代码,在orderservice中向userservice发送请求

@Autowired
//Spring提供的,发送http请求的方法
private RestTemplate restTemplate;

public Order queryOrderById(Long orderId) {
    // 1.查询订单
    Order order = orderMapper.findById(orderId);
    // 2.利用RestTemplate发起http请求,查询用户
    // 2.1.url路径
    String url = "http://127.0.0.1:8081/user/" + order.getUserId();
    // 2.2.发送http请求,实现远程调用
    //放Get请求getForObject
    User user = restTemplate.getForObject(url, User.class);
    // 3.封装user到Order
    order.setUser(user);
    // 4.返回
    return order;

启动完成后,访问:http://localhost:8080/order/101
在这里插入图片描述
可以看到访问成功

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牛总来学习了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值