• springcloud微服务(一)(了解微服务、eureka注册中心、Ribbon负载均衡)



    一 微服务技术栈介绍

    在这里插入图片描述

    微服务治理、缓存技术、异步通信、分布式搜索技术、持续继承(DevOps)
    
    • 1

    在这里插入图片描述

    在这里插入图片描述

    二、认识微服务

    2.1 服务架构演变

    单体结构优缺点:
    
    • 1

    在这里插入图片描述

    微服务:
    
    • 1

    在这里插入图片描述

    2.2 Spring Cloud

    在这里插入图片描述

    三 服务拆分

    3.1 服务拆分注意事项

    1.不同微服务,不能重复开发相同业务
    2.微服务数据独立,不要访问其他微服务的数据库 
    3.微服务可以将自己的业务暴露为接口,供其他微服务调用
    
    • 1
    • 2
    • 3

    源码在D/idea Project/cloudcode-master
    在这里插入图片描述

    3.2 服务拆分

    案例分析:
    
    • 1

    在这里插入图片描述

    3.2.1 如何发送http请求,做远程调用

    spring提供的RestTemplate可以发送各种各样的http请求。
    
    • 1

    在这里插入图片描述
    步骤:

    1.注册RestTemplate(在启动器中)

    /**
        * Description: 创建RestTemplate并注入Spring容器
        * @date:2022/7/27 12:07
        * @params: []
        * @return: org.springframework.web.client.RestTemplate
        */
        @Bean
        public RestTemplate restTemplate(){
            return new RestTemplate();
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    1. 修改order-service中的OrderService的queryOrderById方法(利用RestTemplate中的getForObject方法,告诉它请求的路径和返回值的类型,就会把返回的json转换成对应的类型)
    public Order queryOrderById(Long orderId) {
            // 1.查询订单
            Order order = orderMapper.findById(orderId);
            // TODO: 2021/8/15  2.查询用户
            User user = restTemplate.getForObject("http://localhost:8081/user/" + order.getUserId(), User.class);
            // 3. 将用户信息封装进订单
            order.setUser(user);
            // 4.返回
            return order;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    四、 Eureka注册中心

    4.1 Eureka的作用

    Eureka架构中,微服务角色有两类:
    	*EurekaServer: 服务端,注册中心
    			** 记录服务信息
    			** 心跳监控
    	*EurekaClient:客户端
    			**Provoder:服务提供者
    						*** 注册自己的信息到EurekaServer
    						*** 每隔30秒向EurekaServer发送心跳
    			** consumer:服务消费者,例如案例中的order-service
    						***根据服务名称从EurekaServer中拉取服务列表
    						***基于服务列表做负载均衡,选中一个微服务后发起远程调用				
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    在这里插入图片描述

    4.2 Eureka实栈

    4.2.1 创建maven模块,继承父模块、引入maven引来

    <dependencies>
            <dependency>
                <groupId>org.springframework.cloudgroupId>
                <artifactId>spring-cloud-starter-netflix-eureka-serverartifactId>
            dependency>
        dependencies>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    4.2.2 创建启动类

    @EnableEurekaServer
    @SpringBootApplication
    public class EurekaApplication {
        public static void main(String[] args) {
            SpringApplication.run(EurekaApplication.class, args);
    
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    4.2.3 配置好application.yml文件

    server:
      port: 10086 # 服务端口
    spring:
      application:
        name: eurekaserver # eureka的服务名称
    eureka:
      client:
        service-url: # eureka的地址信息
          defaultZone: http://127.0.0.1:10086/eureka
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    访问地址,服务注册
    在这里插入图片描述

    4.2.4 将user-service服务注册到EurekaServer

    1.引入依赖(user-service模块中)
    
    • 1
    
            <dependency>
                <groupId>org.springframework.cloudgroupId>
                <artifactId>spring-cloud-starter-netflix-eureka-clientartifactId>
            dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    2.在user-service的application.yml文件中,配置如下:
    
    • 1
    spring:
      application:
        name: eurekaserver # eureka的服务名称
    eureka:
      client:
        service-url: # eureka的地址信息
          defaultZone: http://127.0.0.1:10086/eureka
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    如果想给一个服务启动多个实例,idea中 Copy Configuration
    
    • 1

    在这里插入图片描述

    4.2.5 服务拉取

    order-service可以基于服务名称拉取到user-service的两个实例信息,实现负载均衡。
    
    • 1

    在这里插入图片描述
    访问http://localhost:8080/order/101和http://localhost:8080/order/102
    发现user-service控制台有信息,说明两次服务均被拉取到,实现了负载均衡和远程调用。

    五 负载均衡Ribbon

    5.1 负载均衡流程

    在这里插入图片描述

    5.2 负载均衡策略

    配置文件方式和代码方式
    轮询和随机
    
    • 1
    • 2

    在这里插入图片描述

    5.3 Ribbon的懒加载

    Ribbon默认是用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过配置开启饥饿加载。
    在这里插入图片描述

  • 相关阅读:
    实用 - Java后端面试经历(经验分享)适用于2~3年
    JS——数组相关知识点汇总
    如何将微软 Office 宏转换为 ONLYOFFICE 宏
    树表的查找
    springboot基于web的游泳馆信息管理系统毕业设计源码281444
    bugku-web-文件上传
    Netty(三)NIO-进阶
    (学习笔记)数仓建模
    OKHttp请求上传文件
    YOLOX论文讲解和无人机检测项目实战
  • 原文地址:https://blog.csdn.net/weixin_45139640/article/details/125999023