eureka是什么?

 eureka是Netflix的子模块之一,也是一个核心的模块,eureka里有2个组件,一个是EurekaServer(一个独立的项目) 这个是用于定位服务以实现中间层服务器的负载平衡和故障转移,另一个便是EurekaClient(我们的微服务) 它是用于与Server交互的,可以使得交互变得非常简单:只需要通过服务标识符即可拿到服务。

与spring-cloud的关系:

Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现(可以对比Zookeeper)。

Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。

而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。SpringCloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。

角色关系图:

springboot搭建eureka的server和client spring eureka作用_spring

如何使用?

在spring-cloud项目里面加入依赖

 eureka客户端:

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

  eureka服务端:

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

eureka服务端项目里面加入以下配置:

erver:

port: 3000
eureka:
   server:
     enable-self-preservation: false  #关闭自我保护机制
     eviction-interval-timer-in-ms: 4000 #设置清理间隔(单位:毫秒 默认是60*1000)
   instance:
     hostname: localhost

client:

registerWithEureka: false #不把自己作为一个客户端注册到自己身上
     fetchRegistry: false  #不需要从服务端获取注册信息(因为在这里自己就是服务端,而且已经禁用自己注册了)
     serviceUrl:
       defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka

当然,不是全部必要的,这里只是把我这里的配置copy过来了

然后在spring-boot启动项目上 加入注解:@EnableEurekaServer 就可以启动项目了

@EnableEurekaServer
@SpringBootApplication
public class AppEureka {

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

    }
}

如果看见这个图片,那么说明你就搭建好了:

springboot搭建eureka的server和client spring eureka作用_spring_02

这个警告只是说你把他的自我保护机制关闭了

eureka客户端配置:

server:

port: 6000
eureka:
   client:
     serviceUrl:
         defaultZone: http://localhost:3000/eureka/  #eureka服务端提供的注册地址 参考服务端配置的这个路径


  instance:
   

instance-id: power-1 #此实例注册到eureka服务端的唯一的实例ID 
     prefer-ip-address: true #是否显示IP地址
     leaseRenewalIntervalInSeconds: 10 #eureka客户需要多长时间发送心跳给eureka服务器,表明它仍然活着,默认为30 秒 (与下面配置的单位都是秒)
     leaseExpirationDurationInSeconds: 30 #Eureka服务器在接收到实例的最后一次发出的心跳后,需要等待多久才可以将此实例删除,默认为90秒



spring:

application:
     name: server-power #此实例注册到eureka服务端的name

然后在客户端的spring-boot启动项目上 加入注解:@EnableEurekaClient 就可以启动项目了 这里就不截图了我们直接来看效果图:

springboot搭建eureka的server和client spring eureka作用_spring_03

这里我们能看见 名字叫server-power的(图中将其大写了) id为 power-1的服务 注册到我们的Eureka上面来了 至此,一个简单的eureka已经搭建好了。