从零开始学习Spring-Cloud之Eureka搭建

Eureka是什么?

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

Eureka与Spring-Cloud的关系?

Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现(可以对比Zookeeper)。
Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。
而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。SpringCloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。

角色关系图:

假设我们搭建了一个Eureka Server注册中心,然后分别有一个用户服务和订单服务像注册中心注册,这样他们就可以通过注册中心来相互调用。当然如果有其他的服务也可以调用,只要调用的服务已在注册中心注册过。
从零开始学习Spring-Cloud之Eureka搭建_第1张图片

接下来我们开始搭建Eureka Server(服务注册中心)

1.首先我创建一个Maven工程,pom文件中添加Springboot依赖代表是一个springboot项目:


     org.springframework.boot
     spring-boot-starter-parent
     2.0.2.RELEASE

2.该工程下创建一个注册中心模块,取名为Eureka3000(3000是端口号,目的是为了等会搭建集群区分),pom文件中添加依赖:


    
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-server
        
        
            org.springframework.boot
            spring-boot-starter-web
        
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                Finchley.SR2
                pom
                import
            
        
    

3.配置
我们在resources下面创建application.yml文件,进行如下配置:

server:
  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

4.启动测试
我们新建一个启动类:

@SpringBootApplication
//开启服务端
@EnableEurekaServer
public class Eureka3000Application {
    public static void main(String[] args) {
        SpringApplication.run(Eureka3000Application.class);
    }
}

然后去浏览器输入:localhost:3000回车
从零开始学习Spring-Cloud之Eureka搭建_第2张图片
如果能看到上面的图片,那么就说明你搭建成功。
但是这只是代表我们搭建了一个注册中心,在上面我们还没有注册任何服务,因此,接下来我们继续搭建一个user服务并且在注册中心注册。

搭建User服务

1.同样地在父工程下创建一个子模块取名为user5000(5000代表端口号),pom文件中引入依赖:

   
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
        
            org.springframework.boot
            spring-boot-starter-web
        
    
    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                Finchley.SR2
                pom
                import
            
        
    

2.在resources新建application.yml文件进行配置:

server:
  port: 5000
eureka:
  client:
    serviceUrl:
        defaultZone: http://localhost:3000/eureka/  #eureka服务端提供的注册地址 参考服务端配置的这个路径
  instance:
    instance-id: user-1 #此实例注册到eureka服务端的唯一的实例ID 
    prefer-ip-address: true #是否显示IP地址
    leaseRenewalIntervalInSeconds: 10 #eureka客户需要多长时间发送心跳给eureka服务器,表明它仍然活着,默认为30 秒 (与下面配置的单位都是秒)
    leaseExpirationDurationInSeconds: 30 #Eureka服务器在接收到实例的最后一次发出的心跳后,需要等待多久才可以将此实例删除,默认为90秒
spring:
  application:
    name: server-user #此实例注册到eureka服务端的name 

3.启动测试
我们新建一个启动类:

@SpringBootApplication
@EnableEurekaClient //开启eureka客户端
public class UserApplication {
    public static void main(String[] args) {
        SpringApplication.run(UserApplication.class);
    }
}

然后依次启动注册中心,user服务客户端,看到如下所示就说明你搭建成功了:
在这里插入图片描述

你可能感兴趣的:(springcloud)