【Spring Cloud 系列】 二、Spring Cloud Eureka 的第一印象
Eureka : 翻译翻译,找到了!(惊讶语气)
Spring CLoud 中的 Spring Cloud Eureka,用于 分布式项目中的服务治理。是对Netflix 套件中的Eureka 的二次封装。
Spring Cloud Eureka:注册服务,发现服务,治理服务,配置服务。
下面我将展开我对Eureka 的学习过程,
源码我放在了码云,这里大概是3个项目
eureka_server 负责 注册服务
eureka_client 负责暴露接口
eureka_consumer 负责 负载均衡 对 Eureka Client 接口的调用,RestTemplate和LoadBalanceClient 来完成负载
来讲一讲 基本用法,这也是这篇随笔的目的,这篇文章的篇幅不会太长,原文请结合大神的文章,前三篇
根据 中的Eureka的入门Demo
关系即: Eureka Server 负责注册 Eureka Client 、Eureka Consumer等 DiscoverClient,
Eureka Client 有若干台,而外部调用Eureka Client 的接口,
由唯一入口Eureka Consumer来提供负载均衡,去调用 其中的一台Eureka Client中的接口
你觉得,有必要,可以看看源码,里面备注很详细的,下面贴一点
eureka_server
/**
* @EnableEurekaServer 注解启动一个 服务的注册中心,
* 默认情况下,注册服务中心 会把自己作为客户端 来 尝试注册自己,需要在application.properties中禁用
* eureka.client.register-with-eureka=false
* eureka.client.fetch-registry=false
*/
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
//.. }
配置文件:
spring.application.name= eureka-server
server.port=1001 eureka.instance.hostname=localhost
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
eureka_client
/**
* @EnableDiscoveryClient 激活Eureka 中DiscoveryClient实现,这样才能
* 在Controller中 输出服务
*/
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaClientApplication { public static void main(String[] args) {
SpringApplication.run(EurekaClientApplication.class, args);
}
} /**
* @RestController 等同于 @Controller && @ResponseBody
*/
@RestController
public class HelloDiscoveryClient { @Autowired
DiscoveryClient discoveryClient; @GetMapping("/hi")
public String sayHello(){
String services = "Applications: " + discoveryClient.getServices();
System.out.println(services);
return services;
} }
配置文件
spring.application.name=euraka-client server.port=2001
eureka.client.service-url.defaultZone=http://localhost:1001/eureka/
eureka_consumer
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaConsumerApplication { @Bean
public RestTemplate restTemplate(){
return new RestTemplate();
} public static void main(String[] args) {
SpringApplication.run(EurekaConsumerApplication.class, args);
}
} @RestController
public class HelloConsumerController { /**
* 注入 LoadBalancerClient ,它是Spring cloud 提供的 负载均衡 客户端
*/ @Autowired
LoadBalancerClient loadBalancerClient; @Autowired
RestTemplate restTemplate; /**
* @GetMapping("/consumer")
* @RequestMapping(value = "/consumer",method = RequestMethod.GET)
* 这2种写法 是一个意思
*
* @return
*/
@GetMapping("/consumer")
//@RequestMapping(value = "/consumer",method = RequestMethod.GET)
public String hi(){
//获得服务的事例,通过loadBalancerClient的choose函数来负载均衡的选出一个eureka-client的服务实例
ServiceInstance serviceInstance = loadBalancerClient.choose("euraka-client"); String url = "http://" + serviceInstance.getHost() + ":" + serviceInstance.getPort() + "/hi"; System.out.println(url);
//这个服务实例的基本信息存储在ServiceInstance中,然后通过这些对象中的信息拼接出访问/dc接口的详细地址,最后再利用RestTemplate对象实现对服务提供者接口的调用
return restTemplate.getForObject(url,String.class); }
}
配置文件
spring.application.name=eureka-consumer
server.port=2101 eureka.client.service-url.defaultZone=http://localhost:1001/eureka/
最后希望,对您有帮助!
其中遇到的坑:
eureka.client.service-url.defaultZone=http://localhost:1001/eureka/
这个配置文件 教程给出的是
eureka.client.serviceUrl.defaultZone=http://localhost:1001/eureka/
最为小白基本懵逼了,还好,自己摸索出来
【Spring Cloud 系列】 二、Spring Cloud Eureka 的第一印象的更多相关文章
- Spring Boot系列二 Spring @Async异步线程池用法总结
1. TaskExecutor Spring异步线程池的接口类,其实质是java.util.concurrent.Executor Spring 已经实现的异常线程池: 1. SimpleAsyncT ...
- Spring Boot系列(二) Spring Boot 之 REST
Rest (Representational Stat Transer) 是一种软件架构风格. 基础理论 架构特性 性能 可伸缩 简化的统一接口 按需修改 组件通信透明 可移植 可靠性 架构约束 C/ ...
- Spring Cloud系列教程第九篇-Eureka自我保护机制
Spring Cloud系列教程第九篇-Eureka自我保护机制 本文主要内容: 1:自我保护介绍 2:导致原因分析 3:怎么禁止自我保护 本文是由凯哥(凯哥Java:kagejava)发布的< ...
- Spring Cloud(二):Eureka 服务注册中心
前言 服务治理 随着业务的发展,微服务应用也随之增加,这些服务的管理和治理会越来越难,并且集群规模.服务位置.服务命名都会发生变化,手动维护的方式极易发生错误或是命名冲突等问题.而服务治理正是为了解决 ...
- Spring框架系列(8) - Spring IOC实现原理详解之Bean实例化(生命周期,循环依赖等)
上文,我们看了IOC设计要点和设计结构:以及Spring如何实现将资源配置(以xml配置为例)通过加载,解析,生成BeanDefination并注册到IoC容器中的:容器中存放的是Bean的定义即Be ...
- Spring框架系列(2) - Spring简单例子引入Spring要点
上文中我们简单介绍了Spring和Spring Framework的组件,那么这些Spring Framework组件是如何配合工作的呢?本文主要承接上文,向你展示Spring Framework组件 ...
- Spring框架系列(6) - Spring IOC实现原理详解之IOC体系结构设计
在对IoC有了初步的认知后,我们开始对IOC的实现原理进行深入理解.本文将帮助你站在设计者的角度去看IOC最顶层的结构设计.@pdai Spring框架系列(6) - Spring IOC实现原理详解 ...
- Spring框架系列(7) - Spring IOC实现原理详解之IOC初始化流程
上文,我们看了IOC设计要点和设计结构:紧接着这篇,我们可以看下源码的实现了:Spring如何实现将资源配置(以xml配置为例)通过加载,解析,生成BeanDefination并注册到IoC容器中的. ...
- Spring框架系列(9) - Spring AOP实现原理详解之AOP切面的实现
前文,我们分析了Spring IOC的初始化过程和Bean的生命周期等,而Spring AOP也是基于IOC的Bean加载来实现的.本文主要介绍Spring AOP原理解析的切面实现过程(将切面类的所 ...
- Spring框架系列(10) - Spring AOP实现原理详解之AOP代理的创建
上文我们介绍了Spring AOP原理解析的切面实现过程(将切面类的所有切面方法根据使用的注解生成对应Advice,并将Advice连同切入点匹配器和切面类等信息一并封装到Advisor).本文在此基 ...
随机推荐
- Siemens PLC分类和基本性能指标
PLC分类 整体式plc也成为单元式,特点是电源,中央处理器单元以及I/O借口都集成在一个机壳内. 标准摸板试结构化,也成为组合式,特点是电源,中央处理器单元模板以及I/O模板在结构上都是相互独立的, ...
- SQL面试50题
1.查询课程编号为“01”的课程比“02”的课程成绩高的所有学生的学号(重点) SELECT a.s_id,a.s_score FROM (') as a INNER JOIN (') as b on ...
- ## 0521Day04内部类
[重点] Math公式 静态导入 正则表达式 内部类 访问修饰符 [Math] Math包的相关方法: round:四舍五入:-10.9==>-11/-11.2==>-11 floor:向 ...
- 《腾讯网UED体验设计之旅》读后感
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- 百万年薪架构师一文整理RabbitMQ、ActiveMQ、RocketMQ、Kafka
一般来说,大型应用通常会被拆分成多个子系统,这些子系统可能会部署在多台机器上,也可能只是一台机器的多个进程中,这样的应用就是分布式应用.在讨论分布式应用时,很多初学者会把它和集群这个概念搞混,因为从部 ...
- 接口(interface)的使用
类实现接口就具有接口的功能 实现可以多实现,实现多个接口 package cm.aff.abst; /* 接口(interface)是与类并行的一个概念 1. 接口可以看做是一个特殊的抽象类,是常量与 ...
- 画出决策边界线--plot_2d_separator.py源代码【来自python机器学习基础教程】
import numpy as np import matplotlib.pyplot as plt from .plot_helpers import cm2, cm3, discrete_scat ...
- 如何基于 echarts 在柱状图或条形图上实现转换率?(有想法吗?)
目录 需求 探索一 探索二 探索三 转换实践思路1 转换实践思路2 其他思路 探索四(揭晓答案) 答案篇说明 backgroundColor 用法 双柱合一 始终在轴的中间 百分在变,但是距离轴的距离 ...
- 【asp.net core 系列】2 控制器与路由的恩怨情仇
0. 前言 在上一篇文章中,我们初步介绍了asp.net core,以及如何创建一个mvc项目.从这一篇开始,我将为大家展示asp.net core 的各种内容,并且尝试带领大家来挖掘其中的内在逻辑. ...
- @Transactional 注解失效场景
@Transactional可以用在接口.类.类方法上. 作用于类:当把@Transactional注解放在类上时,表示该类的所有public方法都配置了该事物注解. 作用于方法:表示该方法配置了事物 ...