欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringCloud 学习笔记(3)Eureka

程序员文章站 2022-04-03 10:19:06
Eureka服务注册中心1 什么是EurekaNetflix在涉及Eureka时,遵循的就是API原则.Eureka是Netflix的有个子模块,也是核心模块之一。Eureka是基于REST的服务,用于定位服务,以实现云端中间件层服务发现和故障转移,服务注册与发现对于微服务来说是非常重要的,有了服务注册与发现,只需要使用服务的标识符,就可以访问到服务,而不需要修改服务调用的配置文件了,功能类似于Dubbo的注册中心,比如Zookeeper.......

Eureka服务注册中心

1 什么是Eureka

  • Netflix在涉及Eureka时,遵循的就是API原则.
  • Eureka是Netflix的有个子模块,也是核心模块之一。Eureka是基于REST的服务,用于定位服务,以实现云端中间件层服务发现和故障转移,服务注册与发现对于微服务来说是非常重要的,有了服务注册与发现,只需要使用服务的标识符,就可以访问到服务,而不需要修改服务调用的配置文件了,功能类似于Dubbo的注册中心,比如Zookeeper.
  • Eureka 包含两个组件:Eureka Server 和 Eureka Client.

Eureka Server 提供服务注册,各个节点启动后,回在EurekaServer中进行注册,这样Eureka Server中的服务注册表中将会储存所有课用服务节点的信息,服务节点的信息可以在界面中直观的看到.

Eureka Client 是一个Java客户端,用于简化EurekaServer的交互,客户端同时也具备一个内置的,使用轮询负载算法的负载均衡器。在应用启动后,将会向EurekaServer发送心跳 (默认周期为30秒) 。如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,EurekaServer将会从服务注册表中把这个服务节点移除掉 (默认周期为90s).

2 三大角色

Eureka Server:提供服务的注册与发现
Service Provider:服务生产方,将自身服务注册到Eureka中,从而使服务消费方能狗找到
Service Consumer:服务消费方,从Eureka中获取注册服务列表,从而找到消费服务

3 构建eureka 服务

1 选择对应的jar包
SpringCloud 学习笔记(3)Eureka
这里不要怂选最新的版本

<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka-server -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka-server</artifactId>
    <version>1.4.7.RELEASE</version>
</dependency>

2 yml文件

server:
  port: 7001

eureka:
  instance:
    hostname: localhost  #服务端的实例名称
  client:
    register-with-eureka: false #是否注册自己
    fetch-registry: false #如果为false 则表示自己为注册中心
    service-url:
      defaultZore: http://${eureka.instance.hostname}:${server.port}/eureka/

启动中间遇到一个问题

  • 错误: 找不到或无法加载主类
  • mvn clean compile 后解决
    启动后浏览器查看页面:http://localhost:7001/
    搭建成功

4 将项目注册到Eureka

  1. 添加jar包
		<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka-server</artifactId>
            <version>1.4.7.RELEASE</version>
        </dependency>
  1. 修改配置文件 yml
eureka:
  client:
    service-url:
      defaultZone: http://localhost:7001/eureka/
  1. 主启动类添加@EnableEurekaClient注解
@EnableEurekaClient
  1. 先启动7001服务端后启动客户端,页面上有对应的项目就是注册成功了
    SpringCloud 学习笔记(3)Eureka

5 EureKa自我保护机制

某时刻某一个微服务不可用,eureka不会立即清理,依旧会对该微服务的信息进行保存!
SpringCloud 学习笔记(3)Eureka
eureka认为虽然收不到实例的心跳,但它认为实例还是健康的,eureka会保护这些实例,不会把它们从注册表中删掉

6 获取微服务信息

pom添加监控依赖

<!--actuator完善监控信息-->
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

// 启动类 开启服务发现客户端的注解,可以用来获取一些配置的信息,得到具体的微服务
@EnableDiscoveryClient

public Object discovery() {
    // 获取微服务列表的清单
    List<String> services = client.getServices();
    System.out.println("discovery=>services:" + services);
    // 得到一个具体的微服务信息,通过具体的微服务id,applicaioinName;
    List<ServiceInstance> instances = client.getInstances("SPRINGCLOUD-PROVIDER-DEPT");
    for (ServiceInstance instance : instances) {
        System.out.println(
                instance.getHost() + "\t" + // 主机名称
                        instance.getPort() + "\t" + // 端口号
                        instance.getUri() + "\t" + // uri
                        instance.getServiceId() // 服务id
        );
    }
    return this.client;
}

7 Euaeka 集群配置

1 新建springcloud-eureka-7002、springcloud-eureka-7003 模块
2 修改本机host文件
C:\Windows\System32\drivers\etc

127.0.0.1     eureka7001.com
127.0.0.1     eureka7002.com
127.0.0.1     eureka7003.com

3 修改yml文件

server:
  port: 7001

eureka:
  instance:
    hostname: eureka7001.com  #服务端的实例名称
  client:
    register-with-eureka: false #是否注册自己
    fetch-registry: false #如果为false 则表示自己为注册中心
    service-url:
      defaultZore: http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

4 注册服务

  # 注册中心7001-7003
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

著名的CAP理论指出,一个分布式系统不可能同时满足C (一致性) 、A (可用性) 、P (容错性),由于分区容错性P再分布式系统中是必须要保证的,因此我们只能再A和C之间进行权衡。

Zookeeper 保证的是 CP —> 满足一致性,分区容错的系统,通常性能不是特别高
Eureka 保证的是 AP —> 满足可用性,分区容错的系统,通常可能对一致性要求低一些

本文地址:https://blog.csdn.net/qq_38095257/article/details/114261590

相关标签: java eureka