微服务Eureka

>>强大,10k+点赞的 SpringBoot 后台管理系统竟然出了详细教程!

springcloud的核心组件之一 Eureka

Spring Cloud是一个全家桶式的技术栈,并且提供了很多组件。例如Eureka-注册中心、Ribbon-负载均衡、Feign-服务之间调用、Hystrix-熔断器、Zuul-网关等核心组件。

场景引出:

假如现在我们要开发一个庞大的物流系统,要实现从入库到打包发货,那么它的业务流程则是:

  1. 创建入库单,验收商品并上架。

  2. 上架完成以后 库存应加上相应的商品数量。

  3. 创建出库单,进行拣货复核并打包发货。

  4. 库存商品应该减去相应的数量微服务Eureka

简介这个过程则需要经过入库模块、库存模块、在库模块、出库模块等。但是存在的一个问题就是 这些单独的服务之间是如何进行互相调用的呢?这时候就需要Eureka注册中心了,专门负责各种服务的注册、发现。

Eureka由两部分组成:Eureka Server 和 Eureka Client

Eureka Server用于注册服务。
Eureka Server用于注册服务,各个节点启动以后会在Eureka的服务端进行注册,这样服务端注册表中就会保存服务节点的信息,从而使服务消费方能够找到。
Eureka Client分为:服务消费者和服务提供者:
Service Provider服务提供方,将自身服务注册到Eureka,在服务注册后,客户端会向Eureka Server发送心跳,每30秒向服务端 发一次心跳,同时更新注册信息。如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。
Service Consumer:服务消费方,从Eureka获取注册服务列表,从而能够消费服务。微服务Eureka

Eureka Server服务端案例

1:服务端实现

1:引入Eureka Server所依赖的包

 <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
            <version>2.2.3.RELEASE</version>
        </dependency>
    </dependencies>
    <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>
    </dependencyManagement>

2:添加完成后,在我们的启动类中添加注解@EnableEurekaServer

@EnableEurekaServer
@SpringBootApplication
public class SpringcloudApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringcloudApplication.classargs);
    }

}

3:修改配置文件

#服务端口
server.port=8081
#服务名称
spring.application.name=eureka-server
#服务地址
eureka.instance.hostname=localhost
#不向注册中心注册自己
eureka.client.register-with-eureka=false
#开启注册中心的保护机制,默认是开启
eureka.server.enable-self-preservation=true
#设置保护机制的阈值,默认是0.85
eureka.server.renewal-percent-threshold=0.4
#注册中心路径,如果有多个eureka server,
# 如果需要配置其他eureka server的地址,用","进行区分,
# 如"http://address:8080/eureka,http://address:8081/eureka"
eureka.client.service-url.default-zone=http://${eureka.instance.hostname}:${server.port}/eureka

微服务Eureka4:查看注册中心

微服务Eureka

2:客户端实现

1:引入eureka client所依赖的包

 <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            <version>2.2.3.RELEASE</version>
        </dependency>
    </dependencies>
    <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>
    </dependencyManagement>

2:添加完成后,在我们的启动类中添加注解@EnableEurekaClient

@EnableEurekaClient
@SpringBootApplication
public class SpringcloudClientApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringcloudClientApplication.classargs);
    }

}

3:修改配置文件

#服务端口
server.port=8082
#服务名称
spring.application.name=eureka-client-01
#服务地址
eureka.instance.hostname=localhost

#注册中心路径,表示向这个注册中心注册服务,如果向注册中心注册多个服务,用“,”进行分隔
eureka.client.serviceUrl.defaultZone=http://localhost:8082/eureka
#心跳间隔10s,默认30s。每一个服务配置后,心跳间隔和心跳超时时间会被保存在server端,
eureka.instance.lease-renewal-interval-in-seconds=10
#心跳超时时间10s,默认90s。从client端最后一次发出心跳后,达到设置的时间没有再次发出心跳,表示服务不可用,将会把它从注册中心删除
eureka.instance.lease-expiration-duration-in-seconds=10

微服务Eureka

4:访问注册中心地址 本例为:http://localhost:8055/

微服务Eureka

这样我们就成功把服务注册到了注册中心中。

结语:

下篇讲述springcloud的第二个组件Ribbon

微服务Eureka

原文始发于微信公众号(coding途中):微服务Eureka