SpringCloud
苍穹尘
文能提笔安天下,武能上"码"定乾坤。
展开
-
SpringCloud系列一:简介
1、微服务: 原作者马丁.福勒(Martin Fowler) 论文网址:https://martinfowler.com/articles/microservices.html 微服务:强调的是服务的大小,它关注的是某一个点,是具体解决某一个问题/提供落地对应服务的一个服务应用,狭意的看,可以看作Eclipse里面的一个个微服务工程/或者Module。 微服务架构:微服务架构是⼀种架构模式,...原创 2019-05-03 18:20:32 · 364 阅读 · 0 评论 -
Nacos简介
Nacos是阿里巴巴开源的一款支持服务注册与发现,配置管理以及微服务管理的组件。用来取代以前常用的注册中心(zookeeper , eureka等等),以及配置中心(spring cloud config等等)。Nacos是集成了注册中心和配置中心的功能,做到了二合一。 Nacos gitHub : https://github.com/alibaba/nacos Nocos 文档 :htt...原创 2019-05-06 11:59:28 · 3353 阅读 · 0 评论 -
SpringCloud系列十五:Config-实际运用
一、配置文件托管到GitLab1、在文件夹springcloud-config下新建配置文件springcloud-config-dept-client.ymlspring: profiles: active: - dev---server: port: 8001spring: profiles: dev application: name:...原创 2019-05-04 17:11:14 · 1008 阅读 · 0 评论 -
SpringCloud系列十四:Config-基本使用
一、配置文件托管到GitLab1、新建文件夹springcloud-config2、在文件夹下新建配置文件application.ymlspring: profiles: active: - dev---spring: profiles: dev #开发环境 application: name: springcloud-config-atguig...原创 2019-05-04 16:39:12 · 269 阅读 · 0 评论 -
SpringCloud系列十三:Config-简介
1.分布式系统面临的–配置问题 微服务意味着要将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务。由于每个服务都需要必要的配置信息才能运行,所以一套集中式的动态的配置管理设施是必不可少的。SpringCloud提供了ConfigServer来解决这个问题,我们每一个微服务自己带着一个application.yml,上百个配置文件的管理。2、简介 Spr...原创 2019-05-04 15:49:34 · 324 阅读 · 0 评论 -
SpringCloud系列十二:Zuul
Zuul包含了对请求的路由和过滤两个最主要的功能: 其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础。 Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。1、新...原创 2019-05-04 15:38:51 · 174 阅读 · 0 评论 -
SpringCloud系列十一:HystrixDashboard
除了隔离依赖服务的调用以外,Hystrix还提供了准实时的调用监控(Hystrix Dashboard),Hystrix会持续地记录所有通过Hystrix发起的请求的执行信息,并以统计报表和图形的形式展示给用户,包括每秒执行多少请求多少成功,多少失败等。Netflix通过hystrix-metrics-event-stream项目实现了对以上指标的监控。Spring Cloud也提供了Hystr...原创 2019-05-04 15:17:01 · 153 阅读 · 0 评论 -
SpringCloud系列十:Hystrix-服务降级
整体资源快不够了,忍痛将某些服务先关掉,待渡过难关,再开启回来。服务降级处理是在客户端实现完成的,与服务端没有关系。1、修改公共工程microservicecloud-api(1)、在注解@FeignClient中添加fallbackFactory属性值//fallbackFactory用来指定处理服务降级的类@FeignClient(value = "MICROSERVICECLOUD...原创 2019-05-04 14:57:00 · 426 阅读 · 0 评论 -
SpringCloud系列九:Hystrix-服务熔断
服务熔断:熔断机制是应对雪崩效应的一种微服务链路保护机制。当扇出链路的某个微服务不可用或者响应时间太长时,会进行服务的降级,进而熔断该节点微服务的调用,快速返回"错误"的响应信息。当检测到该节点微服务调用响应正常后恢复调用链路。在SpringCloud框架里熔断机制通过Hystrix实现。Hystrix会监控微服务间调用的状况,当失败的调用到一定阈值,缺省是5秒内20次调用失败就会启动熔断机制。...原创 2019-05-04 14:37:34 · 224 阅读 · 0 评论 -
SpringCloud系列八:Hystrix-简介
1、分布式系统面临的问题 复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免地失败。服务雪崩: 多个微服务之间调用的时候,假设微服务A调用微服务B和微服务C,微服务B和微服务C又调用其它的微服务,这就是所谓的“扇出”。如果扇出的链路上某个微服务的调用响应时间过长或者不可用,对微服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,所谓的“雪崩效应”。 对...原创 2019-05-04 14:17:05 · 242 阅读 · 0 评论 -
SpringCloud系列七:负载均衡-Feign
一、简介 Feign是一个声明式WebService客户端。使用Feign能让编写Web Service客户端更加简单, 它的使用方法是定义一个接口,然后在上面添加注解,同时也支持JAX-RS标准的注解。Feign也支持可拔插式的编码器和解码器。Spring Cloud对Feign进行了封装,使其支持了Spring MVC标准注解和HttpMessageConverters。Feign可以与Eu...原创 2019-05-04 14:09:30 · 210 阅读 · 0 评论 -
SpringCloud系列六:负载均衡-Ribbon
一、简介: LB,即负载均衡(Load Balance),在微服务或分布式集群中经常用的一种应用。负载均衡简单的说就是将用户的请求平摊的分配到多个服务上,从而达到系统的HA。常见的负载均衡有软件Nginx,LVS,硬件 F5等。分为两种:集中式LB: 即在服务的消费方和提供方之间使用独立的LB设施(可以是硬件,如F5, 也可以是软件,如nginx), 由该设施负责把访问请求通过某种策略转发至...原创 2019-05-04 13:32:26 · 197 阅读 · 0 评论 -
SpringCloud系列五:Eureka-集群
1、仿照eureka注册中心工程microservicecloud-eureka-7001新建eureka注册中心工程microservicecloud-eureka-7002和eureka注册中心工程microservicecloud-eureka-70032、找到C:\Windows\System32\drivers\etc路径下的hosts文件。添加域名映射127.0.0.1 eur...原创 2019-05-03 21:50:21 · 180 阅读 · 0 评论 -
SpringCloud系列四:Eureka-基本使用
一、新建Eureka注册中心工程microservicecloud-eureka-70011、引入依赖<dependencies> <!--eureka-server服务端 --> <dependency> <groupId>org.springframework.cloud</groupId> ...原创 2019-05-03 19:18:13 · 493 阅读 · 0 评论 -
SpringCloud系列三:Eureka-简介
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现(请对比Zookeeper)。 Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。 而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就可以通过 Eureka S...原创 2019-05-03 18:19:31 · 323 阅读 · 0 评论 -
SpringCloud系列二:基本使用
一、创建父工程microservicecloud。用来做依赖管理。 引入依赖,切记是packaging是pom模式。<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8&l...原创 2019-05-03 18:20:40 · 186 阅读 · 0 评论 -
EnableDiscoveryClient与EnableEurekaClient的区别
Spring Cloud版本:Angle -> Brixton -> Camden -> Dalston -> Edgware -> Finchley一、Dalston或更早期的版本 为了启用服务注册发现功能。需要在主启动类上增加@EnableDiscoveryClient或者@EnableEurekaClient注解,例如以下代码:@EnableEurekaC...原创 2019-05-06 15:11:52 · 19534 阅读 · 2 评论