springcloud之Eureka注册中心

参考博客:https://www.cnblogs.com/ityouknow/p/6854805.htmlhtml

背景:

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

  RPC远程调用框架的核心设计思想:在于注册中心,由于注册中心是管理每一个服务与服务之间的一种依赖关系(服务治理的概念)。spring

  什么是服务治理?apache

  服务中心:后端

  

  服务中心又称注册中心,管理各类服务功能包括服务的注册、发现、熔断、负载、降级等,好比dubbo admin后台的各类功能。有了服务中心调用关系会有什么变化,画几个简图来帮忙理解:浏览器

  一、项目A调用项目B缓存

  正常调用项目A请求项目B:springboot

 

  有了服务中心以后,任何一个服务都不能直接去掉用,都须要经过服务中心来调用:服务器

 

  二、项目A调用项目B,项目B在调用项目C架构

  这时候调用的步骤就会为两步:第一步,项目A首先从服务中心请求项目B服务器,而后项目B在从服务中心请求项目C服务。

  上面的项目只是两三个相互之间的简单调用,可是若是项目超过20个30个呢,在15年末的时候我司分布式的项目就达到了二十几个,画一张图来描述几十个项目之间的相互调用关系全是线条,任何其中的一个项目改动,就会牵连好几个项目跟着重启,巨麻烦并且容易出错。经过服务中心来获取服务你不须要关注你调用的项目IP地址,由几台服务器组成,每次直接去服务中心获取可使用的服务去调用既可。

  因为各类服务都注册到了服务中心,就有了去作不少高级功能条件。好比几台服务提供相同服务来作均衡负载;监控服务器调用成功率来作熔断,移除服务列表中的故障点;监控服务调用时间来对不一样的服务器设置不一样的权重等等。

 

1、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的基本架构,由3个角色组成:

一、Eureka Server

  • 提供服务注册和发现

二、Service Provider

  • 服务提供方
  • 将自身服务注册到Eureka,从而使服务消费方可以找到

三、Service Consumer

  • 服务消费方
  • 从Eureka获取注册服务列表,从而可以消费服务

  Spring Cloud官网的定义比较抽象,咱们能够从简单的东西开始。Spring Cloud是基于Spring Boot的, 最适合用于管理Spring Boot建立的各个微服务应用。要管理分布式环境下的各个Spring Boot微服务,必然存在服务的注册问题。因此咱们先从服务的注册谈起。既然是注册,必然有个管理注册中心的服务器,各个在Spring Cloud管理下的Spring Boot应用就是须要注册的client。

  Spring Cloud使用erureka server,  而后全部须要访问配置文件的应用都做为一个erureka client注册上去。eureka是一个高可用的组件,它没有后端缓存,每个实例注册以后须要向注册中心发送心跳,在默认状况下erureka server也是一个eureka client ,必需要指定一个 server。

2、实例展现

项目架构:

 

 

  一、 建立Eureka Server

  (1)、工程的maven依赖(建立工程时候选中Eureka后,自动关联)

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.dyh</groupId>
    <artifactId>springcloud_eurekaclient</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springcloud_eurekaclient</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.RELEASE</spring-cloud.version>
    </properties>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </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>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <repositories>
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
        </repository>
    </repositories>

</project>
View Code

  (2)、启动一个服务注册中心,只须要一个注解@EnableEurekaServer,这个注解须要在springboot工程的启动application类上加:

@EnableEurekaServer @SpringBootApplication public class SpringcloudOneApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudOneApplication.class, args); } }

  (3)、eureka是一个高可用的组件,它没有后端缓存,每个实例注册以后须要向注册中心发送心跳(所以能够在内存中完成),在默认状况下erureka server也是一个eureka client ,必需要指定一个 server。eureka server的配置文件application.yml

server: port: 8761 eureka: instance: hostname: localhost client: registerWithEureka: false fetchRegistry: false serviceUrl: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

  配置文件简介:

  • register-with-eureka :表示是否将本身注册到Eureka Server,默认为true。
  • fetch-registry :表示是否从Eureka Server获取注册信息,默认为true。

  注意:只有上面两个属性都设置为false,才能是Eureka service。

  • serviceUrl.defaultZone :设置与Eureka Server交互的地址,查询服务和注册服务都须要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可以使用 , 分隔。

  (4)、eureka server 是有界面的,启动工程,打开浏览器访问:http://localhost:8761,界面以下:因为尚未注册服务,因此没有发现服务。
  

 

 

   二、建立Eureka Client(当client向server注册时,它会提供一些元数据,例如主机和端口,URL,主页等。Eureka server 从每一个client实例接收心跳消息。 若是心跳超时,则一般将该实例从注册server中删除。)

  (1)、工程的maven依赖(建立工程后自动生成)

 

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.dyh</groupId>
    <artifactId>springcloud_eurekaclient</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springcloud_eurekaclient</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.RELEASE</spring-cloud.version>
    </properties>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </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>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <repositories>
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
        </repository>
    </repositories>

</project>
View Code

  (2)、经过注解@EnableEurekaClient 代表本身是一个eurekaclient。

@EnableEurekaClient @SpringBootApplication @RestController public class SpringcloudEurekaclientApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudEurekaclientApplication.class, args); } @Value("${server.port}") String port; @RequestMapping("/hi") public String home(@RequestParam String name) { return "hi "+name+",i am from port:" +port; } }

  (3)、仅仅@EnableEurekaClient是不够的,还须要在配置文件中注明本身的服务注册中心的地址,application.yml配置文件以下:

    注意:须要指明spring.application.name,这个很重要,这在之后的服务与服务之间相互调用通常都是根据这个name 。

eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ server: port: 8762 spring: application: name: service-hi

 

  启动工程,打开http://localhost:8761 ,即eureka server 的网址:

  

  能够看到,发现了一个服务注册到了服务上了(首先这个服务必须是运行的)。

 

  这时打开 http://localhost:8762/hi?name=forezp ,你会在浏览器上看到 :

  

三、springcloud默认负载均衡

3、集群的使用

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

  一、高可用配置是“你中有我,我中有你”,最重要是配置时候名字必须相同。

  二、集群配置

  

  在注册过程当中,保证只有一台注册中心服务,有对应服务信息数据,当高可用的服务挂掉,对应的服务信息数据,会转移同步到另外高可用的服务器上。

 4、Eureka的自我保护机制

  参考博客:https://www.jianshu.com/p/ee4785a212f6

  一下是Server与Client端的配置(关闭自我保护机制,默认是开启的)

相关文章
相关标签/搜索