【黑马程序员】SpringCloud——Eureka

文章目录

  • 前言
  • 一、提供者与消费者
    • [1. 服务调用关系](#1. 服务调用关系)
  • 二、远程调用的问题
  • [三、eureka 原理分析](#三、eureka 原理分析)
    • [1. eureka 的作用](#1. eureka 的作用)
  • [四、Eureka 案例](#四、Eureka 案例)
    • [1. 搭建 eureka 服务](#1. 搭建 eureka 服务)
    • [1. 服务注册](#1. 服务注册)
      • [1.1 注册 user-service](#1.1 注册 user-service)
      • [1.2 启动 user-service](#1.2 启动 user-service)
      • [3. order-service 完成服务注册](#3. order-service 完成服务注册)
    • [3. 服务发现](#3. 服务发现)
      • [1. 在 order-service 完成服务拉取](#1. 在 order-service 完成服务拉取)
  • 总结

前言

跟着B站的黑马程序员学习 SpringCloud,语言为java,目前是第二个学习内容

课程传送门:SpringCloud------Eureka


一、提供者与消费者

1. 服务调用关系

  • 服务提供者:暴露接口给其他微服务调用
  • 服务消费者:调用其他微服务提供的接口
  • 提供者与消费者角色其实是相对

二、远程调用的问题

三、eureka 原理分析

  • 问:消费者该如何获取服务提供者具体信息?

    ① 服务提供者启动时向 eureka 注册自己的信息

    ② eureka 保存这些信息

    ③ 消费者根据服务名称向 eureka 拉取提供者信息

  • 问:如果有多个服务提供者,消费者该如何选择?

    ① 服务消费者利用负载均衡算法,从服务列表中挑选一个

  • 问:消费者如何感知服务提供者健康状态?

    ① 服务提供者会每隔 30 秒向 EurekaServer 发送心跳请求,报告健康状态

    ② eureka 会更新记录服务列表信息,心跳不正常会被剔除

    ③ 消费者就可以拉取到最新的信息

1. eureka 的作用

在 Eureka 架构中,微服务角色有两类:

  1. EurekaServer:服务端,注册中心

    ① 记录服务信息

    ② 心跳监控

  2. EurekaClient:客户端

    ① Provider:服务提供者

    ② consumer:服务消费者

  3. Provider:服务提供者

    ① 注册自己的信息到 EurekaServer

    ② 每隔 30 秒向 EurekaServer 发送心跳

  4. consumer:服务消费者

    ① 根据服务名称从 EurekaServer 拉取服务列表

    ② 基于服务列表作负载均衡,选中一个微服务后发起远程调用

四、Eureka 案例

  • 搭建 EurekaServer

    ① 引入 eureka-server 依赖

    ② 添加 @EnableEurekaServer 注解

    ③ 在 application.yml 中配置 eureka 地址

  • 服务注册

    ① 引入 eureka-server 依赖

    ② 在 application.yml 中配置 eureka 地址

  • 服务发现

    ① 引入 eureka-server 依赖

    ② 在 application.yml 中配置 eureka 地址

    ③ 给 RestTemplate 添加 @LoadBalanced 注解

    ④ 用服务提供者的服务名称远程调用

1. 搭建 eureka 服务

1. 服务注册

1.1 注册 user-service

1.2 启动 user-service

3. order-service 完成服务注册

3. 服务发现

1. 在 order-service 完成服务拉取


总结

以上就是本章要讲的内容,本文仅仅简单复述了老师讲课的文本内容,内容有误麻烦联系。

相关推荐
LUCIAZZZ21 分钟前
Java设计模式基础问答
java·开发语言·jvm·spring boot·spring·设计模式
KotlinKUG贵州2 小时前
Spring开发,从Kotlin开始
spring boot·spring·kotlin
木头左2 小时前
Docker 容器化基础:镜像、容器与仓库的本质解析
docker·容器·eureka
攒了一袋星辰3 小时前
Spring类型转换融入IOC生命周期
java·后端·spring
考虑考虑3 小时前
Springboot3.4.x中的RestClient 和 RestTemplate
spring boot·后端·spring
大白爱琴3 小时前
八股文——JVM
java·jvm·spring
我叫小白菜4 小时前
【Java_EE】Spring MVC
java·spring·mvc
~Yogi7 小时前
今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存
学习·spring·缓存
程序员Bears12 小时前
Spring Cloud Hystrix熔断机制:构建高可用微服务的利器
spring cloud·hystrix·微服务