SpringCloud系列篇:核心组件之注册中心组件

Welcome Huihui's Code World ! !

接下来看看由辉辉所写的关于SpringCloud的相关操作吧

目录

Welcome Huihui's Code World ! !

一.注册中心组件是什么

二.注册中心组件的详解 

生活例子

例子分析

三. 代码演示注册中心组件的特点

1.依赖引入

(1)pom

(2)yml

①消费者

②生产者

2.生产者

启动类

controller

3.消费者

启动类

controller


上篇我详细的讲解了SpringCloud到底是什么,也通过生活中的例子去生动说明了,大家如果对于SpringCloud还是又疑问的话,可以看一下上一篇博文

那么这篇我就来详述一下SpringCloud中的核心组件--注册中心组件,也还是会结合生活例子来说明,这样也利于理解。

一.注册中心组件是什么

        注册中心是一种分布式系统中的组件,用于管理服务实例的注册和发现。在微服务架构中,服务可以被拆分成多个小的模块,这些模块可能部署在不同的主机和容器中。因此,为了让一个服务可以访问其他服务,它需要知道其他服务的地址和端口信息。而注册中心就是用来管理这些信息的。

        注册中心组件通常提供以下功能:

  1. 服务注册:服务提供者将自己的服务注册到注册中心中,包括服务名称、IP地址、端口号等信息。
  2. 服务发现:服务消费者从注册中心中查询可用的服务列表,并选择一个可用的服务进行调用。
  3. 服务健康检查:注册中心能够检测服务是否健康,及时剔除不健康的服务实例,避免服务调用失败。
  4. 负载均衡:注册中心可以根据一定的负载均衡策略,为服务消费者选择一个合适的服务实例进行调用。

二.注册中心组件的详解 

      如果只是说注册中心组件的定义,感觉太官方了,脑海中不能出现一个画面感,所以我这里按照自己的理解,给大家举一个通俗易懂的例子


生活例子

假设你需要看病

你去了一家大型医院

这个医院有很多个科室(类似于微服务)

SpringCloud系列篇:核心组件之注册中心组件_第1张图片

...

每个科室都提供不同的医疗服务。你需要看的是内科,但是你不知道内科是在哪个楼层、哪个区域。这个时候你通常会找到导诊台,去询问内科位于哪个楼层的哪个区域

SpringCloud系列篇:核心组件之注册中心组件_第2张图片

然后导诊台中的工作人员便会去告诉你具体的位置


例子分析

例子中的导诊台就相当于注册中心的这个组件,导诊台中管理着这个医院各个科室的信息,注册中心组件中管理着其他服务的地址和端口信息。有了导诊台,我们看病就不需要在整个医院中无脑寻找对应科室了,同样的,有了注册中心的组件,我们也不需要在整个服务中去寻找对应的服务。这样就可以节省很多的时间,提高效率。

三. 代码演示注册中心组件的特点

这里写的代码就是一个生产者拿取消费者中返回回来的信息【水蜜桃】

1.依赖引入

(1)pom

这里写一个module代表生产者,一个module代表消费者。其中也需要引入依赖,两个module中肯定有相同的依赖,那么我们可以把整个两个module都写在同一个maven项目下,

SpringCloud系列篇:核心组件之注册中心组件_第3张图片然后再把相同的依赖放在那个大项目中,如果两个module有用到其他的依赖,则可以直接在自身的pom文件中引入相应依赖。

父项目的依赖




    4.0.0
    
    org.example
    
    cloud
    
    1.0-SNAPSHOT
    
    pom

    
    
        provider
        consumer
    

    
    
        
        2.7.8
        
        2021.0.3
        
        2021.0.1.0
    

    
    
        
        
            org.springframework.boot
            spring-boot-starter-test
        
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-discovery
        
        
        
            org.springframework.cloud
            spring-cloud-starter-openfeign
        
        
        
            org.projectlombok
            lombok
        
        
        
            org.springframework.cloud
            spring-cloud-loadbalancer
        
    

    
    
        
            
            
                org.springframework.boot
                spring-boot-dependencies
                ${spring-boot.version}
                pom
                import
            
            
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
            
            
                com.alibaba.cloud
                spring-cloud-alibaba-dependencies
                ${spring-cloud-alibaba.version}
                pom
                import
            
        
    


其中也需要在整个父项目中说明自己的子模块

SpringCloud系列篇:核心组件之注册中心组件_第4张图片

相应的,子模块中也需要指明自己的父项目【因为需要用到父项目中的依赖】

SpringCloud系列篇:核心组件之注册中心组件_第5张图片SpringCloud系列篇:核心组件之注册中心组件_第6张图片

(2)yml

①消费者
server:
  port: 8082
spring:
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
  application:
    name: consumer
②生产者
server:
  port: 8081
spring:
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
  application:
    name: provider

2.生产者

启动类

package com.provider.main;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication // 使用@SpringBootApplication注解,表示这是一个Spring Boot应用
@EnableDiscoveryClient // 使用@EnableDiscoveryClient注解,启用服务发现功能
public class ProviderApplication { // 定义主类为ProviderApplication

    public static void main(String[] args) { // 定义主方法
        SpringApplication.run(ProviderApplication.class, args); // 运行Spring Boot应用,传入当前类和命令行参数
    }

}

controller

package com.provider.main;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class TestController {

    // 使用@RequestMapping注解,指定该处理方法对应的URL路径为"/hello"
    @RequestMapping("/hello")
    public String hello() {
        // 返回一个字符串"
        return "我吃";
    }

}

3.消费者

启动类

package com.consumer.main;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication // 启动类,包含@SpringBootConfiguration和@EnableAutoConfiguration注解
@EnableDiscoveryClient // 启用服务发现功能
public class ConsumerApplication {

    // 使用@LoadBalanced注解,表示该Bean会被负载均衡器管理
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate(); // 创建并返回一个RestTemplate实例
    }

    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args); // 运行消费者应用,传入当前类和命令行参数
    }

}

controller

package com.consumer.main;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

// 使用@RestController注解,表示这是一个处理HTTP请求的控制器类
@RestController
public class TestController {

    // 使用@Autowired注解,将RestTemplate实例注入到当前类中
    @Autowired
    private RestTemplate restTemplate;

    // 使用@RequestMapping注解,指定该处理方法对应的URL路径为"/get_hello"
    @RequestMapping("/get_hello")
    public String get_hello() {

        // 使用restTemplate的getForObject方法,向"http://provider/hello"发送GET请求,并将响应结果转换为String类型
        return restTemplate.getForObject("http://provider/hello", String.class);
    }

}

如果我们没有用到注册中心,那么我们在消费者中需要拿到生产者的数据,就必须要将请求它的那个路径写明白

SpringCloud系列篇:核心组件之注册中心组件_第7张图片

这样写其实会非常麻烦,我这里为了演示,所以就只写了一个,那么如果是在实际项目中呢?会有许多的服务,那么我们每一个都需要给他写的很详尽,如果有一天这个请求的路径变了,不在localhost中,或者是请求的这个hello变了,那我们还需要找到对应的调用它的那些地方去修改,总之就是非常的麻烦。这里我用到的注册中心的组件是阿里的nacos。

只要我们引入相应的依赖


        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-discovery
        
server:
  port: 8082
spring:
  cloud:
#nacos依赖
    nacos:
      discovery:
        server-addr: localhost:8848
  application:
    name: provider

并且下载nacos这个软件

nacos下载地址icon-default.png?t=N7T8https://nacos.io/zh-cn/docs/what-is-nacos.html

SpringCloud系列篇:核心组件之注册中心组件_第8张图片

解压之后运行就可以使用它啦

SpringCloud系列篇:核心组件之注册中心组件_第9张图片

它的访问路径是8848/nacos

SpringCloud系列篇:核心组件之注册中心组件_第10张图片

首次进入需要登录,默认账户和密码都是nacos

SpringCloud系列篇:核心组件之注册中心组件_第11张图片

使用了nacos之后,我们的服务都会被他管理,这样我们就只需要填写相应的服务名,它就会帮我们去找对应的服务了

SpringCloud系列篇:核心组件之注册中心组件_第12张图片

运行之后也是可以拿到里面的数据的

SpringCloud系列篇:核心组件之注册中心组件_第13张图片

好啦,今天的分享就到这了,希望能够帮到你呢! 

你可能感兴趣的:(Spring,Cloud,spring,cloud,spring,后端)