首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Springboot与Eureka注册中心集群项目实战

1 Eureka注册中心

1.1需求分析

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

心来管理微服务信息。

为什么 要用注册中心?

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

端口。

2、微服务会实时上报自己的状态,注册中心统一管理这些微服务的状态,将存在问题的服务踢出服务列表,客户

端获取到可用的服务进行调用。

1.3 Eureka注册中心

1.3.1 Eureka介绍

Spring Cloud Eureka 是对Netflflix公司的Eureka的二次封装,它实现了服务治理的功能,Spring Cloud Eureka提

供服务端与客户端,服务端即是Eureka服务注册中心,客户端完成微服务向Eureka服务的注册与发现。服务端和

客户端均采用Java语言编写。下图显示了Eureka Server与Eureka Client的关系:

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

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

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

1.3.2 Eureka Server搭建

1.3.2.1 单机环境搭建

1、创建basicpro-govern-center工程:

2、添加依赖

在父工程添加:(有了则不用重复添加)

spring‐cloud‐dependencies

Finchley.SR1

pom

import

在Eureka Server工程添加:

spring‐cloud‐starter‐netflix‐eureka‐server

3、启动类

@EnableEurekaServer//标识这是一个Eureka服务

@SpringBootApplication

public class GovernCenterApplication {

public static void main(String[] args) {

SpringApplication.run(GovernCenterApplication.class, args);

}

}

4、@EnableEurekaServer

需要在启动类上用@EnableEurekaServer标识此服务为Eureka服务

5、从其它服务拷贝application.yml和logback-spring.xml。

application.yml的配置内容如下:

server:

port: 50101 #服务端口

spring:

application:

name: basicpro‐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:清理失效结点的间隔,在这个时间段内如果没有收到该结点的上报则将结点从服务

列表中剔除。

5、启动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进入自保护模式,不再将微服务从服务列

表删除。

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

1.3.2.2 高可用环境搭建

Eureka Server 高可用环境需要部署两个Eureka server,它们互相向对方注册。如果在本机启动两个Eureka需要

注意两个Eureka Server的端口要设置不一样,这里我们部署一个Eureka Server工程,将端口可配置,制作两个

Eureka Server启动脚本,启动不同的端口,如下图:

1、在实际使用时Eureka Server至少部署两台服务器,实现高可用。

2、两台Eureka Server互相注册。

3、微服务需要连接两台Eureka Server注册,当其中一台Eureka死掉也不会影响服务的注册与发现。

4、微服务会定时向Eureka server发送心跳,报告自己的状态。

5、微服务从注册中心获取服务地址以RESTful方式发起远程调用。

配置如下:

1、端口可配置

server:

port: $ #服务端口

2、Eureka服务端的交互地址可配置

eureka:

client:

registerWithEureka: true #服务注册,是否将自己注册到Eureka服务中

fetchRegistry: true #服务发现,是否从Eureka中获取注册信息

serviceUrl: #Eureka客户端与Eureka服务端的交互地址,高可用状态配置对方的地址,单机状态配置自己(如果

不配置则默认本机8761端口)

defaultZone: $

3、配置hostname

Eureka 组成高可用,两个Eureka互相向对方注册,这里需要通过域名或主机名访问,这里我们设置两个Eureka服

务的主机名分别为 eureka01、eureka02。

完整的eureka配置如下:

eureka:

client:

registerWithEureka: true #服务注册,是否将自己注册到Eureka服务中

fetchRegistry: true #服务发现,是否从Eureka中获取注册信息

serviceUrl: #Eureka客户端与Eureka服务端的交互地址,高可用状态配置对方的地址,单机状态配置自己(如果

不配置则默认本机8761端口)

defaultZone: $

server:

enable‐self‐preservation: false #是否开启自我保护模式

eviction‐interval‐timer‐in‐ms: 60000 #服务注册表清理间隔(单位毫秒,默认是60*1000)

instance:

hostname: $

4、在IDEA中制作启动脚本

启动1:

运行两个启动脚本,分别浏览:

http://localhost:50101/

http://localhost:50102/

Eureka主画面如下:

1.3.3 服务注册

1.3.3.1 将cms注册到Eureka Server

下边实现cms向Eureka Server注册。

1、在cms服务中添加依赖

spring‐cloud‐starter‐netflix‐eureka‐client

2、在application.yml配置

eureka:

client:

registerWithEureka: true #服务注册开关

fetchRegistry: true #服务发现开关

serviceUrl: #Eureka客户端与Eureka服务端进行交互的地址,多个中间用逗号分隔

defaultZone: $

instance:

prefer‐ip‐address: true #将自己的ip地址注册到Eureka服务中

ip‐address: $

instance‐id: $:$ #指定实例id

3、在启动类上添加注解

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

4、刷新Eureka Server查看注册情况

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20200711A0CF7F00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券