• Spring Cloud之Eureka注册中心


    在前后端分离架构中,服务层被拆分成了很多的微服务,微服务的信息如何管理?Spring Cloud中提供服务注册中 心来管理微服务信息。

    为什么 要用注册中心?

    1、微服务数量众多,要进行远程调用就需要知道服务端的ip地址和端口,注册中心帮助我们管理这些服务的ip和 端口。

    2、微服务会实时上报自己的状态,注册中心统一管理这些微服务的状态,将存在问题的服务踢出服务列表,客户 端获取到可用的服务进行调用。

    Spring Cloud Eureka 是对Netflix公司的Eureka的二次封装,它实现了服务治理的功能,Spring Cloud Eureka提 供服务端与客户端,服务端即是Eureka服务注册中心,客户端完成微服务向Eureka服务的注册与发现。服务端和 客户端均采用Java语言编写。

    1、Eureka Server是服务端,负责管理各各微服务结点的信息和状态。

    2、在微服务上部署Eureka Client程序,远程访问Eureka Server将自己注册在Eureka Server。

    3、微服务需要调用另一个微服务时从Eureka Server中获取服务调用地址,进行远程调用。

    创建Eureka工程

    加入依赖

    <dependencies>
        <!‐‐ 导入Eureka服务的依赖 ‐‐>
        <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring‐cloud‐starter‐netflix‐eureka‐server</artifactId>
        </dependency>
    </dependencies>

    启动类

    @EnableEurekaServer//标识这是一个Eureka服务
    @SpringBootApplication
    public class GovernCenterApplication {
        public static void main(String[] args) {
            SpringApplication.run(GovernCenterApplication.class, args);
        }
    }

    在启动类上添加@EnableEurekaServer注解,来标识此服务为Eureka服务

    在application.yml的配置内容如下:

    server:
        port: 50101 #服务端口
    spring:
        application:
            name: xc‐govern‐center #指定服务名
    eureka:
        client:
            registerWithEureka: false #服务注册,是否将自己注册到Eureka服务中
            fetchRegistry: false #服务发现,是否从Eureka中获取注册信息
            serviceUrl: #Eureka客户端与Eureka服务端的交互地址,高可用状态配置对方的地址,单机状态配置自己(如果不配置则默认本机8761端口)
              defaultZone: http://localhost:50101/eureka/
        server:
            enable‐self‐preservation: false #是否开启自我保护模式
            eviction‐interval‐timer‐in‐ms: 60000 #服务注册表清理间隔(单位毫秒,默认是60*1000

    registerWithEureka:被其它服务调用时需向Eureka注册

    fetchRegistry:需要从Eureka中查找要调用的目标服务时需要设置为true

    serviceUrl.defaultZone 配置上报Eureka服务地址高可用状态配置对方的地址,单机状态配置自己

    enable-self-preservation:自保护设置。

    eviction-interval-timer-in-ms:清理失效结点的间隔,在这个时间段内如果没有收到该结点的上报则将结点从服务 列表中剔除。

    启动Eureka Server

    启动Eureka Server,浏览50101端口。

      报错:出现红色提示信息: THE SELF PRESERVATION MODE IS TURNED OFF.THIS MAY NOT PROTECT INSTANCE EXPIRY IN CASE OF NETWORK/OTHER PROBLEMS.

                意思:自我保护模式被关闭。在网络或其他问题的情况下可能不会保护实例失效。

    Eureka Server有一种自我保护模式,当微服务不再向Eureka Server上报状态,Eureka Server会从服务列表将此 服务删除,如果出现网络异常情况(微服务正常),此时Eureka server进入自保护模式,不再将微服务从服务列 表删除。

      在开发阶段建议关闭自保护模式。

    二、将服务注册到eureka中

    2.1添加依赖:

    <!‐‐ 导入Eureka客户端的依赖 ‐‐>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring‐cloud‐starter‐netflix‐eureka‐client</artifactId>
    </dependency>

    2.2在application.yml配置:

    eureka:
        client:
            registerWithEureka: true #服务注册开关
            fetchRegistry: true #服务发现开关
            serviceUrl: #Eureka客户端与Eureka服务端进行交互的地址,多个中间用逗号分隔
                defaultZone: ${EUREKA_SERVER:http://localhost:50101/eureka/}
        instance:
            prefer‐ip‐address: true #将自己的ip地址注册到Eureka服务中
            ip‐address: ${IP_ADDRESS:127.0.0.1}
            instance‐id: ${spring.application.name}:${server.port} #指定实例id
        

    2.3在启动类上添加注解:

    在启动类上添加注解 @EnableDiscoveryClient ,表示它是一个Eureka的客户端.

    完。。。

  • 相关阅读:
    什么是重名问题,树型目录结构如何解决这一问题。
    什么是当前目录,什么是相对路径名。
    什么是文件路径名?
    Centos6.7安装chrome
    关于Java开发过程中质量提升-2自动化
    关于Java开发过程中质量提升-1代码格式配置
    java质量提升相关
    完成wamp安装后Mysql配置记录
    树莓派raspi2-ubuntu meta安装配置指导
    mysql数据库批量操作
  • 原文地址:https://www.cnblogs.com/zxh06820/p/13325592.html
Copyright © 2020-2023  润新知