1.Eureka概述

1.1.什么是Eureka

Eureka是Netflix的一个子模块。基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移。

只需要使用服务的标识符,就可以访问到服务,而不需要修改服务调用的配置文件。功能类似于dubbo的注册中心,比如Zookeeper。

Eureka在设计时遵守的是AP原则,而Zookeeper 就是则是CP原则。C一致性(Consistency)、A可用性(Availability)、P分区容错性(Partition tolerance)。

1.2.Eureka架构

                                Eureka  CS架构图

Eureka包含两个组件:Eureka Server和Eureka Client

Eureka Server提供服务注册服务:SpringCloud中的微服务启动后会在Eureka Server中注册,由Server存储所有可用服务微服务节点的信息到服务注册表,可以在Eureka服务启动后界面中看到。

Eureka Client是一个Java的客户端,用于简化Eureka Server的交互,客户端同时也具备内置的、轮询(round-robin)的负载均衡器。在应用启动后,

会向Eureka Server发送心跳(默认30秒)。如果Eureka Server在多个心跳周期没有接收到某个节点的心跳,EurekaServer将会从服务注册表中把这个服务节点移除(默认90秒)。基于EurekaServer的“自我保护”模式,认定微服务是是启动的健康状态,不会注销这个微服务。

1.3.Eureka三大角色

Eureka Server:提供服务注册与发现

Server Provider:服务提供方将自身服务注册到Eureka,从而使服务消费方能够找到

Servcie Consumer:服务消费方从Eureka获取注册服务列表,从而能够消费服务

2.Eureka Server服务注册中心实现

2.1.pom.xml依赖

<dependency>
<groupId>org.springframework.cloud</groupId>
<!--server表明是server端-->
<artifactId>spring-cloud-starter-eureka-server</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
<!--热部署插件-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>

2.2.application.yml

server:
port: 7001 #Eureka配置
eureka:
instance:
hostname: localhost #Eureka服务端的实例名称
client:
register-with-eureka: false #表示是否向Eureka注册中心注册自己,false表示不注册自己
fetch-registry: false #如果为false,则表示自己为注册中心
service-url: #服务注册页面地址
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

2.3.启动类

注意:在启动类上添加@EnableEurekaServer注解标识这个是Server服务注册类

@SpringBootApplication
@EnableEurekaServer //标识是Eureka服务的启动类,可以接受消费者注册进来
public class EurekaServer_7001 {
public static void main(String[] args) {
SpringApplication.run(EurekaServer_7001.class, args);
}
}

启动SpringBoot项目,访问服务注册页面地址http://localhost:7001/:

3.Service Provider服务提供方

3.1.pom.xml依赖

<!--微服务provider方引入eureka-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<!--没有带sever表示就是client客户端-->
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
<!--actuator:完善监控信息-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!--需要拿到实体类,引入api module-->
<dependency>
<groupId>com.fengye</groupId>
<artifactId>springcloud-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>

3.2.application.yml

#spring的配置
spring:
application:
name: springcloud-provider-dept #默认注册进eureka中的实例名称(显示大写) #eureka的配置,确定客户端服务注册到eureka服务列表内
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka/

3.3.启动类

@SpringBootApplication
@EnableEurekaClient //在服务启动后自动注册到eureka中
public class DeptServiceProvider {
public static void main(String[] args) {
SpringApplication.run(DeptServiceProvider.class, args);
}
}

启动注册中心Server与Provider Client类,发现在Eureka注册中心已经注册上了实例:

3.4.注册中心实例显示细节配置

①主机名称:服务名称修改

#eureka的配置,确定客户端服务注册到eureka服务列表内
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka/
instance:
instance-id: springcloud-provider-dept-8001 #修改eureka上默认的服务描述信息

②访问信息有IP地址信息提示

 instance:
instance-id: springcloud-provider-dept-8001 #修改eureka上默认的服务描述信息
prefer-ip-address: true #访问路径可以显示ip地址

③微服务info内容详细信息显示

(1)provider service中pom.xml添加actuator配置:

 <!--actuator:完善监控信息-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

(2)父工程中修改pom.xml添加构建build信息:

 <build>
<finalName>springcloud_helloworld</finalName>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<delimiters>
<delimit>$</delimit>
</delimiters>
</configuration>
</plugin>
</plugins>
</build>

(3)provider service中的application.yml中添加info配置:

#info配置
info:
app.name: fengye-springcloud
company.name: blog.fengye.com
build.artifactId: $project.artifactId$
build.version: $project.version$

之后点击服务重定向info页面不会显示error页面,会重定向获取到info数据:

4.Service Consumer服务消费方

其实服务方和消费方在配置时候没有任何区别,它们都属于Eureka Client组件。只是涉及服务间的调用,所以就把被调方称为提供方,调用方称为消费方。就好比订单微服务,

订单服务肯定需要去调商品微服务接口,所以这个订单微服务对于商品来讲可以理解服务提供方。一个微服务即可以是服务方也同时是提供方。

4.1.pom.xml

<!--微服务provider方引入eureka-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<!--没有带sever表示就是client客户端-->
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
<!--actuator:完善监控信息-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>com.fengye</groupId>
<artifactId>springcloud-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>

4.2.application.yml

#spring的配置
spring:
application:
name: springcloud-consumer-dept #默认注册进eureka中的实例名称(显示大写) #eureka的配置,确定客户端服务注册到eureka服务列表内
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka/
instance:
instance-id: springcloud-consumer-dept-8002 #修改eureka上默认的服务描述信息
prefer-ip-address: true #访问路径可以显示ip地址

4.3.启动类

@SpringBootApplication
@EnableEurekaClient //标识这是一个eureka的client客户端
public class DeptServiceConsumer {
public static void main(String[] args) {
SpringApplication.run(DeptServiceConsumer.class, args);
}
}

启动消费者微服务,访问端口:http://localhost:7001/,发现消费中服务也已经注册进来了:

4.4.服务发现

服务发现是指服务的提供者provider可以通过对外暴露一个服务的发现接口获取Eureka Server中注册的服务信息,同时也可以让consumer调用者进行接口访问。获得

接口请求的数据。

服务发现比较简单,主要是微服务之间进行接口的调用、通信,主要配置如下:

(1)注入DiscoveryClient接口:

@RestController
@RequestMapping("/dept")
public class DeptController {
@Autowired //对外暴露一个服务发现的接口
private DiscoveryClient client; //获取注册进来的微服务的一些消息
@GetMapping("/discovery")
public Object discovery(){
//获取微服务列表的清单
List<String> services = client.getServices();
System.out.println("discovery=>:" + services);
//得到一个具体的微服务信息,通过具体的微服务Application id
List<ServiceInstance> instances = client.getInstances("SPRINGCLOUD-PROVIDER-DEPT");
for (ServiceInstance instance : instances) {
System.out.println(
instance.getHost() + "\t" +
instance.getPort() + "\t" +
instance.getUri() + "\t" +
instance.getServiceId()
);
} return this.client;
}
}

(2)启动类开启服务发现注解:

@SpringBootApplication
@EnableEurekaClient //在服务启动后自动注册到eureka中
@EnableDiscoveryClient //服务发现
public class DeptServiceProvider {
public static void main(String[] args) {
SpringApplication.run(DeptServiceProvider.class, args);
}
}

(3)服务消费者访问接口请求地址:

@RestController
public class DeptConsumerController {
/**
* 消费者:不应该有service实现层
* RestTemplate:提供多种便捷的访问远程http服务的方法,提供简单的restful服务模板(使用简单无脑粗暴)
* 参数类型:(url, requestMap, ResponseBean.class)分别代表REST请求地址、请求参数、HTTP响应转换被转换成的对象类型
*/
@Autowired
private RestTemplate restTemplate; //服务端的请求地址,这里是本机localhost,也可以是其他任意的服务机ip地址
private static final String REST_URL_PREFIX = "http://localhost:8001"; //测试@EnableDiscoveryClient,消费端可以调用服务发现
@RequestMapping("/consumer/dept/discovery")
public Object discovery(){
return restTemplate.getForObject(REST_URL_PREFIX + "/dept/discovery", Object.class);
}
}

最终访问8002端口调用服务提供者请求发现接口,访问到数据:

示例代码已上传至Github地址:

https://github.com/devyf/SpringCloud_Study/tree/main/springcloud_hello

【分布式】SpringCloud(3)--Eureka服务注册与发现的更多相关文章

  1. SpringCloud(3)---Eureka服务注册与发现

    Eureka服务注册与发现 一.Eureka概述 1.Eureka特点 (1) Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移. (2) Eureka 主管服务 ...

  2. SpringCloud系列——Eureka 服务注册与发现

    前言 Eureka是一种基于REST(具像状态传输)的服务,主要用于AWS云中定位服务,以实现中间层服务器的负载平衡和故障转移.本文记录一个简单的服务注册与发现实例. GitHub地址:https:/ ...

  3. java框架之SpringCloud(3)-Eureka服务注册与发现

    在上一章节完成了一个简单的微服务案例,下面就通过在这个案例的基础上集成 Eureka 来学习 Eureka. 介绍 概述 Eureka 是 Netflix 的一个子模块,也是核心模块之一.Eureka ...

  4. SpringCloud之Eureka服务注册与发现(一)

    一 Eureka的基本架构 Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现(请对比Zookeeper). Eureka 采用了 C-S 的设计架构 ...

  5. SpringCloud:Eureka服务注册与发现

    1.Eureka简介 Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现(请对比Zookeeper). Eureka 采用了 C-S 的设计架构.Eu ...

  6. 三(1)、springcloud之Eureka服务注册与发现

    1.认识Eureka ​ Eureka是Netflix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移.服务注册与发现对于微服务架 ...

  7. SpringCloud学习--Eureka 服务注册与发现

    目录 一:构建项目 二:服务注册与发现 为什么选择Eureka,请看上一篇博客 Eureka -- 浅谈Eureka 项目构建 IDEA 选择 New Project 选择 Spring Initia ...

  8. SpringCloud的入门学习之概念理解、Eureka服务注册与发现入门

    1.微服务与微服务架构.微服务概念如下所示: 答:微服务强调的是服务的大小,它关注的是某一个点,是具体解决某一个问题.提供落地对应服务的一个服务应用,狭意的看,可以看作Eclipse里面的一个个微服务 ...

  9. SpringCloud 进阶之Eureka(服务注册和发现)

    1. Eureka 服务注册与发现 Eureka 是一个基于REST的服务,用于服务的的注册与发现; Eureka采用C-S的设计架构,Eureka Server作为服务注册功能的服务器,它是服务注册 ...

随机推荐

  1. TypeScript enum 枚举实现原理

    TypeScript enum 枚举实现原理 反向映射 https://www.typescriptlang.org/docs/handbook/enums.html enum Direction { ...

  2. WiFi & QR Code

    WiFi & QR Code https://github.com/bndw/wifi-card https://wifi.dev.bdw.to/ 扫码登录 WIFI:T:WPA;S:free ...

  3. npm & private npm service & nrm & nvm

    npm & private npm service & nrm & nvm npm server # nrm https://www.cnblogs.com/xgqfrms/t ...

  4. Fast-RTPS简介

    RTPS即DDS中的主要核心通信部分.它提供实时高效的去中心化publish/subscribe通信机制.是ROS-2的核心底层通信组件,也是未来机器人/无人驾驶领域一个必然的方向. 资料参考: ht ...

  5. go语言第一天(变量与基本类型)

    第一个go程序: //导入主函数的包package main//fmt format 包含格式化输入输出import "fmt"//注释 注释不参与程序编译 可以帮助可以程序//行 ...

  6. 一条sql语句的执行过程

    一条select语句执行流程 第一步:连接器 连接器负责跟客户端建立连接.获取权限.维持和管理连接.如果用户名密码验证通过后,连接器会到权限表里面查出你拥有的权限.之后该连接的权限验证都依赖于刚查出来 ...

  7. 解决margin-top无效问题

    当两个空的块级元素嵌套时,如果内部的块设置有margin-top属性,而且父元素没有下边解决方法所述的特征,那么内部块的margin-top属性会绑架父元素(即将margin-top传递凌驾给了父元素 ...

  8. Linux+Tomcat+Jdk1.8+jenkins环境搭建

    1.下载jdk的rpm安装包,这里以jdk-8u191-linux-x64.rpm为例进行说明 下载地址:https://www.oracle.com/technetwork/java/javase/ ...

  9. C++教程01:计算机系统的组成

    教程首发 | 公众号:lunvey 学习C++之前,需要先了解一点基础的计算机知识.毕竟C++是跑在计算机系统上的,我们写的程序都是一段段的指令集. 首台计算机ENIAC问世之后,缺少原理指导.冯诺依 ...

  10. 【产品设计】linux产品设计总结笔记

    Linux 预研产品设计   产品的目的: 1.综合集团内部重复性开发的工作,将多种操作系统统一到科东统一负责 2.明确技术在哪些设备上是可行的,再去拓展.一开始不做平台化产品 3.软件规划需要结合硬 ...