【黑马程序员】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 完成服务拉取


总结

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

相关推荐
xiaolyuh1232 小时前
Spring 框架 核心架构设计 深度详解
spring·设计模式·spring 设计模式
独断万古他化5 小时前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee
likuolei5 小时前
Spring AI框架完整指南
人工智能·python·spring
梵得儿SHI5 小时前
(第四篇)Spring AI 核心技术攻坚:多轮对话与记忆机制,打造有上下文的 AI
java·人工智能·spring·springai生态·上下文丢失问题·三类记忆·智能客服实战案
希忘auto5 小时前
SpringBoot之统一数据返回格式
java·spring
不吃香菜学java5 小时前
spring-依赖注入
java·spring boot·后端·spring·ssm
ja哇5 小时前
Spring AOP 详细讲解
java·后端·spring
海南java第二人5 小时前
Spring Bean生命周期深度剖析:从创建到销毁的完整旅程
java·后端·spring
阿里巴巴P8资深技术专家9 小时前
基于 Spring AI 和 Redis 向量库的智能对话系统实践
人工智能·redis·spring
计算机学姐10 小时前
基于SpringBoot的校园资源共享系统【个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·mysql·spring·信息可视化