SpringCloud Eureka (Netflix)

简介

Euraka 用于服务注册和发现,是Netflix中的一个开源框架。它和 zookeeperConsul一样,都是用于服务注册管理和服务依赖管理。

Euraka 遵循着CAP理论中的A(可用性) P(分区容错性)。

Eureka中分为eureka servereureka client。其中eureka server是作为服务的注册与发现中心。eureka client既可以作为服务的生产者,又可以作为服务的消费者。 

注册中心能解决什么样的问题:

  • 服务注册后,如何被及时发现
  • 服务宕机后,如何及时下线
  • 服务如何有效的水平扩展
  • 服务发现时,如何进行路由
  • 服务异常时,如何进行降级
  • 注册中心如何实现高可用

常见注册中心对比


 eureka 服务消费实现方式:

discoveryClient:通过元数据获取服务信息

loadBalancerClient:Ribbon 的负载均衡器

@LoadBalanced:通过注解开启  Ribbon 的负载均衡器


Eureka自我保护机制

通过配置 eureka.server.enable-self-preservation 来true打开false禁用自我保护机制,默认打开状态,建议生产环境打开此配置。


eureka server 项目构建

  • pom文件引入Eureka server 端依赖。
  • 启动类加入@EnableEurekaServer注解,表示此项目作为Eureka server 端服务。
  • yaml文件配置

非高可用示例

pom文件引入Eureka server 端依赖(SpringCloud的依赖版本号管理通常放到父项目中)

        <!--eureka-server-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    <!--提供SpringCloud的依赖版本号管理-->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring.cloud-version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>

 启动类加入@EnableEurekaServer注解,表示此项目作为Eureka server 端服务

@SpringBootApplication
@EnableEurekaServer
public class EurekaServer1Application {

    public static void main(String[] args) {
        SpringApplication.run(EurekaServer1Application.class, args);
    }

}

yaml文件配置:

server:
  port: 8761  #端口号

eureka:
  server:
    enable-self-preservation: false # true 开启自我保护,false 关闭自我保护,默认开启

  instance:
    hostname: ludb-1 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取

  client:
    registerWithEureka: false #是否将自己注册到注册中心,默认True
    fetchRegistry: false  #是否从注册中心获取注册信息,默认为True

    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/  #注册中心对外暴露的注册地址

spring:
  application:
    name: ludb-server-1 #应用名称

注意 :

  • 非高可用的 eureka server 如果将自己注册到注册中心会报错(因为他自己就是注册中心)。
  • 非高可用的 eureka server 通常不需要从注册中心获取注册信息。

 高可用示例

新增另一个eureka server 项目,与之前单台注册中心仅配置不同

eureka server (V1)

server:
  port: 8761  #端口号

eureka:
  instance:
    hostname: ludb-1 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取
    prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
    instance-id:  ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口

  client:
#    设置服务注册中心地址,指向另一个注册中心,以实现高可用

    serviceUrl:
      defaultZone: http://localhost:8762/eureka/

#    registerWithEureka: false #是否将自己注册到注册中心,默认True
#    fetchRegistry: false  #是否从注册中心获取注册信息,默认为True
#    serviceUrl:
#      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/  #注册中心对外暴露的注册地址

spring:
  application:
    name: ludb-server #应用名称

eureka server (V2)

server:
  port: 8762  #端口号

eureka:
  instance:
    hostname: ludb-2 #主机名(类似于我的电脑里的那个名字吧),不配置的时候将根据应用系统的主机获取
    prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
    instance-id:  ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口
  client:
#    设置服务注册中心地址,指向另一个注册中心,以实现高可用
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

#    registerWithEureka: false #是否将自己注册到注册中心,默认True
#    fetchRegistry: false  #是否从注册中心获取注册信息,默认为True
#    serviceUrl:
#      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/  #注册中心对外暴露的注册地址
spring:
  application:
    name: ludb-server #应用名称

注意: 

  • 两台 eureka server 为相互注册。
  • prefer-ip-address 和 instance-id 的配置是为了eureka server 界面可以展示出IP+端口
  • 两台 eureka server 设置为将自己注册到注册中心,并且从注册中心获取注册信息(默认就是如此所以注释掉了)。
  • 应用名称需要一样。
  • eureka.client.serviceUrl.defaultZone 和 eureka.client.service-url.defaultZone 应该是没有区别的。

效果(加prefer-ip-address 和 instance-id之前):

 效果(加prefer-ip-address 和 instance-id之后):


eureka client 项目构建

  • pom文件引入Eureka client 端依赖。
  • 启动类加入 @EnableEurekaClient 注解,表示此项目作为Eureka Client端服务。
  • yaml文件配置

eureka client 项目构建

application.yaml

server:
  port: 8081

eureka:
  instance:
    prefer-ip-address: true #是否使用IP地址注册(用于eureka展示)
    instance-id:  ${spring.cloud.client.ip-address}:${server.port} #当前客户端IP:端口

  client:
#    设置服务注册中心地址【向注册中心集群注册(注册两台是为了防止第一台宕机还可以挂在第2台上)】
    service-url:
      defaultZone: http://localhost:8761/eureka/,http://localhost:8762/eureka/

    registry-fetch-interval-seconds: 10 #表示10秒拉取一次服务注册信息,默认30秒
    register-with-eureka: true #是否将自己注册到注册中心,默认true

spring:
  application:
    name: ludb-client-1 #应用名称

 pom.xml 引入client端的pom文件

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

启动类

@SpringBootApplication
//如果配置文件配置了注册中心相关配置,则默认开启注册中心注解(@EnableEurekaClient)
@EnableEurekaClient
public class EurekaClient1Application {

    public static void main(String[] args) {
        SpringApplication.run(EurekaClient1Application.class, args);
    }

}

注意:

  • 启动类 如果配置文件配置了注册中心相关配置,则默认开启注册中心注解
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值