学成在线 第9天 讲义-课程预览 Eureka Feign

1 Eureka注册中心 
1.1 需求分析 
在前后端分离架构中,服务层被拆分成了很多的微服务,微服务的信息如何管理?Spring Cloud中提供服务注册中心来管理微服务信息。
为什么 要用注册中心? 
1、微服务数量众多,要进行远程调用就需要知道服务端的ip地址和端口,注册中心帮助我们管理这些服务的ip端口。
2、微服务会实时上报自己的状态,注册中心统管理这些微服务的状态,将存在问题的服务踢出服务列表,客户端获取到可用的服务进行调用。
1.3 Eureka注册中心 
1.3.1 Eureka介绍 
Spring Cloud Eureka 是对Netflflix公司的Eureka的二次封装,它实现了服务治理的功能,Spring Cloud Eureka供服务端与客户端,服务端即是Eureka服务注册中心,客户端完成微服务向Eureka服务的注册与发现。服务端和客户端均采用Java语言编写。下图显示了Eureka ServerEureka Client的关系: 
 
1Eureka Server是服务端,负责管理各各微服务结点的信息和状态。

2、在微服务上部署Eureka Client程序,远程访问Eureka Server将自己注册在Eureka Server。 
3、微服务需要调用另个微服务时从Eureka Server中获取服务调用地址,进行远程调用。
1.3.2 Eureka Server搭建 
1.3.2.1 单机环境搭建 
1、创建xc-govern-center工程:
包结构:com.xuecheng.govern.center
2、添加依赖 
在父工程添加:(有了则不用重复添加)

<dependency>
<groupId>org
.springframework.cloud</groupId>
<artifactId>spring
‐
cloud
‐
dependencies</artifactId>
<version>Finchley
.SR1</version>
<type>pom</type>
<scope>import</scope>
</dependency>

Eureka Server工程添加:

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

3、启动类

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

4@EnableEurekaServer 
需要在启动类上用@EnableEurekaServer标识此服务为Eureka服务
5、从其它服务拷贝application.ymllogback-spring.xml
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:清理失效结点的间隔,在这个时间段内如果没有收到该结点的上报则将结点从服务
列表中剔除。 
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进入自保护模式,不再将微服务从服务列表删除。
在开发阶段建议关闭自保护模式。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值