第二篇:Spring Cloud注册中心Eureka

Spring-Cloud Eureka注册中心

项目码云地址:https://gitee.com/hrabbit/spring-cloud

Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现。也是springcloud体系中最重要最核心的组件之一。

服务注册与发现

在服务化的早期,服务不是很多,服务的注册与发现并不是什么新鲜的名词,Nginx+内部域名服务器方式,甚至Nginx+host文件配置方式也能完成服务的注册与发现。服务上下线需要在nginx,服务器做相应的配置,一旦服务的IP端口发生变化,都需要在nginx上做相应的配置,为了解决这个问题引入服务注册中心。
服务注册,即服务在启动的时候就将服务的IP,端口,版本号等EndPoint注册到注册中心(Eueka,Zookeeper,Consul)对服务进行统一管理.
服务发现,简单的就是说,不管服务上下线,当对某个服务发起请求时,能够快速的从本地缓存或者注册中心的注册列表中,快速找到服务提供者。

传统项目的做法:
正常调用项目A请求项目B

ab.jpg

有了服务中心之后,任何一个服务都不能直接去掉用,都需要通过服务中心来调用

a2b.jpg

使用Eureka实现服务的注册与发现

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

Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用作服务注册服务器。Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器,并提供服务的故障切换支持。Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。

案例实践


Eureka Server

spring cloud已经帮我实现了服务注册中心,我们只需要很简单的几个步骤就可以完成。

1、pom中添加依赖



    org.springframework.cloud
    spring-cloud-starter-eureka-server

2、添加启动代码中添加@EnableEurekaServer注解

package com.hrabbit.eureka;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

/**
 * 服务注册中心
 * @author hrabbit
 */
@SpringBootApplication
@EnableEurekaServer
public class SpringCloudEurekaApplication {

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

3、配置文件

在默认设置下,该服务注册中心也会将自己作为客户端来尝试注册它自己,所以我们需要禁用它的客户端注册行为,在application.yml添加以下配置:

### 服务名称
spring:
  application:
    name: spring-eureka-server1
### 指定端口号
server:
  port: 8081

### eureka配置信息
eureka:
  client:
    #表示是否将自己注册到Eureka Server上,默认为true,当前应用为Eureka Server所以无需注册
        registerWithEureka: false
        #表示是否从Eureka Server获取注册信息,默认为true。因为这是一个单点的Eureka Server,不需要同步其他的Eureka Server节点的数据,故而设为false。
        fetchRegistry: false
        #Eureka Server的访问地址,服务注册和client获取服务注册信息均通过该URL,多个服务注册地址用,隔开
        serviceUrl:
          defaultZone: http://localhost:8081/eureka/
  • eureka.client.register-with-eureka :表示是否将自己注册到Eureka Server,默认为true。
  • eureka.client.fetch-registry :表示是否从Eureka Server获取注册信息,默认为true。
  • eureka.client.serviceUrl.defaultZone :设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8081/eureka ;多个地址可使用 , 分隔。

启动工程后,访问:http://localhost:8000/,可以看到下面的页面,其中还没有发现任何服务

aa.png

集群

注册中心这么关键的服务,如果是单点话,遇到故障就是毁灭性的。在一个分布式系统中,服务注册中心是最重要的基础部分,理应随时处于可以提供服务的状态。为了维持其可用性,使用集群是很好的解决方案。Eureka通过互相注册的方式来实现高可用的部署,所以我们只需要将Eureke Server配置其他可用的serviceUrl就能实现高可用部署。

1、创建application-peer1.yml,作为peer1服务中心的配置,并将serviceUrl指向peer2
### 服务名称
spring:
  application:
    name: spring-eureka-server1
### 指定端口号
server:
  port: 8081

### eureka配置信息
eureka:
  instance:
    hostname: peer1
  client:
    #表示是否将自己注册到Eureka Server上,默认为true,当前应用为Eureka Server所以无需注册
        registerWithEureka: false
        #表示是否从Eureka Server获取注册信息,默认为true。因为这是一个单点的Eureka Server,不需要同步其他的Eureka Server节点的数据,故而设为false。
        fetchRegistry: false
        #Eureka Server的访问地址,服务注册和client获取服务注册信息均通过该URL,多个服务注册地址用,隔开
        serviceUrl:
          defaultZone: http://peer2:8082/eureka/
2、创建application-peer2.yml,作为peer2服务中心的配置,并将serviceUrl指向peer1
### 服务名称
spring:
  application:
    name: spring-eureka-server2
### 指定端口号
server:
  port: 8082

### eureka配置信息
eureka:
  instance:
    hostname: peer2
  client:
    #表示是否将自己注册到Eureka Server上,默认为true,当前应用为Eureka Server所以无需注册
        registerWithEureka: false
        #表示是否从Eureka Server获取注册信息,默认为true。因为这是一个单点的Eureka Server,不需要同步其他的Eureka Server节点的数据,故而设为false。
        fetchRegistry: false
        #Eureka Server的访问地址,服务注册和client获取服务注册信息均通过该URL,多个服务注册地址用,隔开
        serviceUrl:
          defaultZone: http://peer1:8081/eureka/

3、host转换

在hosts文件中加入如下配置


`127.0.0.1 peer1  `

`127.0.0.1 peer2  `

instance.hostname是唯一标识。
由于我们使用了http://peer1这种写法,需要配一下host。Windows的host在/etc/host,mac的在/private/etc

hosts.png
4. mvn打包
#打包
mvn clean package
# 分别以peer1和peeer2 配置信息启动eureka
java -jar spring-cloud-eureka-server1-0.0.1-SNAPSHOT.pom --spring.profiles.active=peer1
java -jar spring-cloud-eureka-server2-0.0.1-SNAPSHOT.pom --spring.profiles.active=peer2
3、启动项目,打开http://localhost:8081
eureka-two.jpg

根据图可以看出peer1的注册中心DS Replicas已经有了peer2的相关配置信息,并且出现在available-replicas中。我们手动停止peer2来观察,发现peer2就会移动到unavailable-replicas一栏中,表示peer2不可用。

到此双节点的配置已经完成。

你可能感兴趣的:(第二篇:Spring Cloud注册中心Eureka)