1. 简介

Eureka是Netflix开发的服务发现框架,并被Spring cloud 收录 并封装成为其服务治理的模块实现

Eureka采用了CS的架构设计,分为 Server端 和 Client端,

Eureka Server: 提供服务注册服务,各个微服务节点通过配置启动后,会在 Server中进行注册,这样Server中的服务注册列表将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观看到

Eureka Client :通过注册中心进行访问, 分为消费方 和 提供方,提供方启动服务, 会注册进 Server中 并发送心跳,(默认周期为30秒),如果Server在多个心跳周期内(默认三个:90s)没有收到该节点的心跳,会将该服务节点中列表中移除, 消费方请求Server端 获取需要的服务节点信息地址等信息,并进行调用

示意图:

2. 单机Eureka Server构建

父工程依赖 控制springcloud 系列的版本

<dependencyManagement>
<dependencies>
<!--spring boot 2.2.2-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.2.2.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

eureka-server pom依赖

<dependencies>
<!-- Eureka server 依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency> <!-- boot web actuator -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency> </dependencies>

yml配置文件:

server:
port: 7001
spring:
application:
name: cloud-eureka-service eureka:
instance:
hostname: localhost #eureka服务端的实例名称
client:
register-with-eureka: false #false表示不向注册中心注册自己
fetch-registry: false #false表示自己端就是注册中心
serviceUrl:
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

主启动配置文件: 使用EnableEurekaServer 注解开启服务自动配置

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

浏览器访问:http://127.0.0.1:7001/

至此一个最基本的Eureka server就搭建完成

3. Eureka Client 端服务提供方搭建

pom依赖 Eureka client

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency> <!-- boot web actuator -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

yml配置

server:
port: 8001 spring:
application:
name: cloud-payment-service #集群部署按照这个名字区分 eureka:
client:
register-with-eureka: true #是否将自己注册到注册中心
fetch-registry: true #是否从服务端抓取已有的注册信息
service-url:
defaultZone: http://localhost:7001/eureka # eureka 服务地址
instance:
instance-id: payment8001 # 修改eureka 管理页面中的 服务 Status 中的服务名
prefer-ip-address: true #访问路径可以显示IP地址

编写controller 提供服务

@RestController
public class PaymentController { @Value("${server.port}")
private String serverPort; @GetMapping(value = "/get/{id}")
public String getPaymentById(@PathVariable("id") Long id) {
return "接受的参数为:"+id+"端口为:"+serverPort
} }

主启动类

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

查看 eureka 监控页面 发现注册服务列表已经有服务注册

图中红色的字是自我保护机制的提示信息 后面讲

4. Eureka Client 端服务消费方搭建

pom依赖和 提供方一样,都是eureka client

yml配置

server:
port: 80 spring:
application:
name: cloud-consummer-service eureka:
client:
register-with-eureka: true #是否将自己注册到注册中心
fetch-registry: true #是否从服务端抓取已有的注册信息
service-url:
defaultZone: http://localhost:7001/eureka #eureka server地址

使用@LoadBalanced 注解构建 RestTemplate,用来获取服务 并调用

加强 RestTemplate ,client 默认使用 Ribbon 技术进行远程调用,后面详说

@Configuration
public class RestTemplateConfig { @Bean
@LoadBalanced
public RestTemplate initRestTemplate(){
return new RestTemplate();
}
}

编写controller 调用 服务

@RestController
@Slf4j
public class OrderController {
//host 为服务名
public static final String PAYMENT_URL="http://CLOUD-PAYMENT-SERVICE"; @Resource
private RestTemplate restTemplate; @GetMapping("/consumer/get/{id}")
public String get(@PathVariable("id") Long id){
return restTemplate.getForObject(PAYMENT_URL+"/get/create/"+id,String.class);
}
}

主启动类

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

查看监控页面 发现服务消费方也注册了进来

调用消费方接口:http://localhost/consumer/get/80

成功调用服务提供方接口 返回信息:接受的参数为:80端口为:8001

实际生产环境中,为了保证高可用,服务注册中心和 服务提供方都会部署集群,下面进行集群部署

5. Eureka Server 集群

将刚刚的 单机 服务项目拷贝一份 并进行修改

修改 yml

互相指定对方服务的地址,相互注册 相互守望

server:
port: 7002
spring:
application:
name: cloud-eureka-service eureka:
instance:
hostname: localhost7002 #eureka服务端的实例名称
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost7001:7001/eureka/ #必须使用hostname集群

填写的地址必须是 对方地址的hostname,可以配置etc/hosts文件,

并且将 register-with-eureka 和 fetch-registry 置为true 才可以相互注册

启动两个服务

发现两个 服务已经互相注册成功 并显示在 集群节点上

6. 服务提供方搭建集群并注册到集群注册中心

同样将之前搭建的 服务提供方 拷贝一份,并修改yaml

修改端口 为8002

spring.application.name 的名称保持一致

server:
port: 8002 spring:
application:
name: cloud-payment-service #集群部署按照这个名字区分 eureka:
client:
register-with-eureka: true #是否将自己注册到注册中心
fetch-registry: true #是否从服务端抓取已有的注册信息
service-url:
defaultZone: http://127.0.0.1:7001/eureka,http://127.0.0.1:7002/eureka
instance:
instance-id: payment8002 # 修改eureka 管理页面中的 服务 Status 中的服务名
prefer-ip-address: true #访问路径可以显示IP地址

启动 两个服务提供方,查看注册中心 发现都已经注册成功

修改服务消费 方配置,指定注册中心集群,多个url使用,分割

defaultZone: http://127.0.0.1:7001/eureka,http://127.0.0.1:7002/eureka

多次调用接口,发现已经轮询调用 连个服务提供方

接受的参数为:80端口为:8001

接受的参数为:80端口为:8002

7. 常用参数

1. eureka.client.register-with-eureka=true(默认)

该项配置说明,是否向注册中心注册自己,在非集群环境下Server端设为为false,表示自己不注册自己

2. eureka.client.fetch-registry=true(默认)

该项配置说明,注册中心只要维护微服务实例清单,不需要作检索服务,在非集群环境下Server端设为为false

3. eureka.instance.lease-renewal-interval-in-seconds=30(默认)

该配置说明,服务提供者会维持一个心跳告诉eureka server 自己的健康,这个就是一个心跳周期

4. eureka.instance.lease-expiration-duration-in-seconds=90(默认)

该配置说明,从最后一次续约时间开始,记时90s 如果还没接受到客户端的心跳则剔除

5. eureka.client.registry-fetch-interval-seconds=30

缓存在调用方的微服务实例清单刷新时间(前提:eureka.client.fetch-registry为true,检索服务列表)

SpringCloud Eureka基本使用的更多相关文章

  1. springcloud(第三篇)springcloud eureka 服务注册与发现 *****

    http://blog.csdn.net/liaokailin/article/details/51314001 ******************************************* ...

  2. SpringCloud Eureka 报错 无法启动问题

    1.SpringCloud Eureka 报错 无法启动基本上都是spring boot的版本与spring cloud的版本不匹配导致的. <dependencyManagement> ...

  3. spring-cloud: eureka之:ribbon负载均衡自定义配置(二)

    spring-cloud: eureka之:ribbon负载均衡自定义配置(二) 有默认配置的话基本上就是轮询接口,现在我们改用自定义配置,同时支持:轮询,随机接口读取 准备工作: 1.eureka服 ...

  4. spring-cloud: eureka之:ribbon负载均衡配置(一)

    spring-cloud: eureka之:ribbon负载均衡配置(一) 比如我有: 一个eureka服务:8761 两个user用户服务: 7900/7901端口 一个movie服务:8010 1 ...

  5. springcloud+eureka简单入门案例

    springcloud+eureka简单入门案例 一.服务提供者 直接提供服务,入门案例没有特别要设置的地方,注意下端口,由于要启动多个服务,可能会冲突 配置文件(src/main/resources ...

  6. 微服务之SpringCloud实战(二):SpringCloud Eureka服务治理

    服务治理 SpringCloud Eureka是SpringCloud Netflix微服务套件的一部分,它基于Netflix Eureka做了二次封装,主要完成微服务的服务治理功能,SpringCl ...

  7. SpringCloud Eureka参数配置项详解

    SpringCloud Eureka参数配置项详解(转) Eureka涉及到的参数配置项数量众多,它的很多功能都是通过参数配置来实现的,了解这些参数的含义有助于我们更好的应用Eureka的各种功能,下 ...

  8. [转帖]springboot+k8s+抛弃springcloud.eureka

    springboot+k8s+抛弃springcloud.eureka https://www.cnblogs.com/lori/p/12048743.html springboot开发微服务框架一般 ...

  9. SpringCloud+Eureka+Feign+Ribbon的简化搭建流程,加入熔断,网关和Redis缓存[2]

    目录 前提:本篇是基于 SpringCloud+Eureka+Feign+Ribbon的简化搭建流程和CRUD练习[1] 的修改与拓展 1.修改consumer的CenterFeign.java,把返 ...

  10. springCloud eureka服务治理集群增加安全认证

    做为SpringCloud Netflix服务套件中的一部分,springCloud eureka基于Netflix Eureka做了二次封装,默认提供WEB管理页面及服务治理. 为了确保在生产环境中 ...

随机推荐

  1. C/C++ 感染标志与空字节感染

    C/C++ 通过搜索PE结构中的空隙部分,对指定文件写入感染标志,作用是,如果程序被感染过则不再继续感染,而搜索空字节,则是要将恶意代码动态的填充到可执行文件中,并劫持执行流,以下代码就是这两种代码的 ...

  2. Flask 框架:运用Ajax实现数据交互

    使用Ajax技术网页应用能够快速地将增量更新呈现在用户界面上,而不需要重载刷新整个页面,这使得程序能够更快地回应用户的操作,如下笔记将简单介绍使用AJAX如何实现前后端数据通信. 前后端发送字符串 前 ...

  3. SpringAOP配置要点

    一.基于配置文件 1.关于aop配置文件相关 <!--配置aop--> <aop:config> <!--配置切入点表达式--> <aop:pointcut ...

  4. Android 子线程更新UI的六种方式

    1.注意: (1)子线程需要切换到UI线程或者主线程去更新线程. (2)但是子线程单独也是可以更新UI的,只是谷歌要求我们需要到UI线程去更新. eg: @Override protected voi ...

  5. 一文搞懂 Vue3 defineModel 双向绑定:告别繁琐代码!

    前言 随着vue3.4版本的发布,defineModel也正式转正了.它可以简化父子组件之间的双向绑定,是目前官方推荐的双向绑定实现方式. vue3.4以前如何实现双向绑定 大家应该都知道v-mode ...

  6. 资深工程师 VSCode C/C++ 必备开发插件

    1.前言 俗话说"工欲善其事,必先利其器",下面介绍几个VSCode提高开发效率的插件,资深工程师必备. 2.基础插件 2.1.Chinese(Simplified) vscode ...

  7. Linux防火墙操作命令(开放或关闭端口)

    在外部访问CentOS中部署应用时,需要通过防火墙管理软件,开端口,或者直接关闭防火墙进行解决(不建议) 常用命令:systemctl start firewalld               #启 ...

  8. JS leetcode 删除排序数组中的重复项 题解分析

    壹 ❀ 引 一日一题,今天的题目来自于leetcode26. 删除排序数组中的重复项,其实在之前我们已经做了一道类似的题目,可参考JS leetcode 移除元素 题解分析,关于本题描述如下: 给定一 ...

  9. Educational Codeforces Round 136 (Rated for Div. 2) A-E

    比赛链接 A 题解 知识点:模拟. 所有点都跑一遍即可. 另外可以不模拟, \(\geq 2*2\) 的情况都可以摆在 \((2,2)\) 这个点,其他摆在 \((1,1)\) . 时间复杂度 \(O ...

  10. NC16590 [NOIP2010]乌龟棋

    题目链接 题目 题目描述 ​ 小明过生日的时候,爸爸送给他一副乌龟棋当作礼物. ​ 乌龟棋的棋盘是一行N 个格子,每个格子上一个分数(非负整数).棋盘第1 格是唯一的起点,第N 格是终点,游戏要求玩家 ...