微服务之Eureka

news/2024/10/31 5:33:33/

🏠个人主页:阿杰的博客
💪个人简介:大家好,我是阿杰,一个正在努力让自己变得更好的男人👨
目前状况🎉:24届毕业生,奋斗在找实习的路上🌟
🚗🚗为了让更多的人看到更优质的博客,阿杰正在努力的更新学习中心中的内容。

文章目录

    • 🌳认识微服务
      • 🍅SpringCloud
    • 🌲Eureka注册中心
      • 🌻搭建eureka注册中心
      • 🌻注册eureka
      • 🌻服务发现

🌳认识微服务

🍅SpringCloud

image-20230220164407359

🌲Eureka注册中心

服务调用出现的问题

  • 服务消费者该如何获取服务提供者的地址信息

    • 服务提供者启动时向eureka注册自己的信息
    • eureka保存这些信息
    • 消费者根据服务名称向eureka拉取提供者信息

    简单来说就是eureka充当家政公司的角色,消费者充当你,提供者充当家政。

    家政上班的时候在公司登记,你去家政公司找家政的时候,他会按照自己的规则派给你一个家政。

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

    • 服务消费者利用负载均衡算法,从服务器列表挑一个
  • 消费者如何得知服务提供者的健康状态

    • 服务提供者会没30 秒向eurekaServer发送心跳请求,报告健康状态
    • eureka会更新状态,剔除不正常的

🌻搭建eureka注册中心

  1. 引用依赖

    <!--eureka服务端-->
    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
    
  2. 启动类添加注解 @EnableEurekaServer

  3. 添加配置

    server:port: 10086 # 服务端口
    spring:application:name: eurekaserver # eureka的服务名称
    eureka:client:service-url:  # eureka的地址信息defaultZone: http://127.0.0.1:10086/eureka
    

🌻注册eureka

  1. 引用依赖

    <!--eureka客户端依赖-->
    <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    
  2. 添加配置

    server:port: 8081 # 服务端口
    spring:application:name: userserver # user的服务名称
    eureka:client:service-url:  # eureka的地址信息defaultZone: http://127.0.0.1:10086/eureka
    

🌻服务发现

  1. 在启动类添加RestTemplate到容器 并添加@LoadBalanced注解

    /*** 创建RestTemplate并注入Spring容器*/
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {return new RestTemplate();
    }
    
  2. 调用服务名就可以使用服务

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

http://www.ppmy.cn/news/26843.html

相关文章

唤醒手腕 Java 后端 Springboot 结合 Redis 数据库学习笔记(更新中)

Redis 基本介绍 Redis Introduction The open source, in-memory data store used by millions of developers as a database, cache, streaming engine, and message broker. 基本概念&#xff1a;redis 是一个开源的、使用 C 语言编写的、支持网络交互的、可基于内存也可持…

Qt中的多线程

Qt中有多种方法实现多线程&#xff1a; QThreadQThreadPool和QPunnable&#xff08;重用线程&#xff09;Qt ConcurrentWorkerScript&#xff08;QML中的线程&#xff09;QThread 在上两篇文章中已经解释了&#xff0c;这里就不再赘述。 QThreadPoo和QRunnable&#xff08;实现…

二、Plugin The chain/event/query function

The chain function 链函数是所有数据处理都在其中进行的函数。在简单过滤器的情况下&#xff08;本节示例的情况&#xff09;&#xff0c;_chain()函数大多是线性函数——因此对于每个传入的缓冲区&#xff0c;也将输出一个缓冲区。下面是一个非常简单的chain函数的实现: sta…

Java线程的6 种状态

Java 线程的状态 Java线程有六种状态&#xff1a; 初始&#xff08;NEW&#xff09;、运行&#xff08;RUNNABLE&#xff09;、阻塞&#xff08;BLOCKED&#xff09;、 等待&#xff08;WAITING&#xff09;、超时等待&#xff08;TIMED_WAITING&#xff09;、终止&#xff08…

【Spring6】| Spring启示录、Spring概述

目录 一&#xff1a;Spring启示录 1. OCP开闭原则 2. 依赖倒置原则DIP 3. 控制反转IoC 二&#xff1a;Spring概述 1. Spring简介 2. Spring8大模块 3. Spring特点 一&#xff1a;Spring启示录 引言&#xff1a;前面我们已经学习了三层架构&#xff1a;表示层、业务层、…

使用 PyTorch+LSTM 进行单变量时间序列预测(附完整源码)

时间序列是指在一段时间内发生的任何可量化的度量或事件。尽管这听起来微不足道&#xff0c;但几乎任何东西都可以被认为是时间序列。一个月里你每小时的平均心率&#xff0c;一年里一只股票的日收盘价&#xff0c;一年里某个城市每周发生的交通事故数。 在任何一段时间段内记…

SQL零基础入门学习(四)

SQL零基础入门学习&#xff08;三&#xff09; SQL INSERT INTO 语句 INSERT INTO 语句用于向表中插入新记录。 SQL INSERT INTO 语法 INSERT INTO 语句可以有两种编写形式。 第一种形式无需指定要插入数据的列名&#xff0c;只需提供被插入的值即可&#xff1a; INSERT …

基于Django的员工管理系统

目录 一、新建项目 二、创建app 三、设计表结构 四、在MySQL中生成表 五、静态文件管理 六、添加页面 七、模板的继承 一、新建项目 django-admin startproject 员工管理系统 二、创建app startapp app01 三、设计表结构 app01/migrations/models.py from django.db impo…