Spring Cloud 微服务,原生云应用及快速入门

微服务,原生云应用

  微服务(Mocrosesrvice)是近几年非常火,它的含义是:使用定义好边界小的独立组件来做好一件事情。微服务是相对于传统单块式架构而言的。
  单块式架构是一份代码,部署和伸缩都是基于单个单元进行的。它的优点是易于部署,但是面临着可用性低、可伸缩性差、集中发布的生命周期以及违反单一功能原则(Single Responssibility principle)。微服务的出现解决了这个问题,它以单个独立的服务来做一个功能,切要做好这个功能。但使用微服务不可避免地讲功能按照边界拆分为单个服务,提现出分布式的特征,这时每个服务之间的通信将是我们要解决的问题。
  Spring Cloud 的出现为我们解决分布式开发常用的问题给出了完整的解决方案。Spring Cloud是基于Spring Boot,为我们提供了配置管理、服务发现、断路器、代理服务等我们在做分布式开发时常用的问题解决方案。
  基于Spring Cloud开的程序特别适合在Docker或者其他专业PaaS(平台服务,如Cloud Foundry)部署,所以又称作原生云应用(Cloud Native Applocation)。

Spring Cloud 快速入门

配置服务

  Spring Cloud提供了Config Server,它有在分布式系统开发中外部配置的功能。通过Config Server 我们集中存储所有应用的配置文件。

  Config Server支持在git或者在文件系统中防止配置文件。可以使用以下格式来区分不同应用的不同配置文件:

/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}/{profile}.properties
/{label}/{application}/{profile}.properties

  Spring Cloud提供了注解@EnableConfigServer来启动配置服务。

服务发现

  Spring Cloud 通过Netflix OSS的eureka来实现服务发现,服务发现的主要目的是为了让内个服务之间可以互相同行。Eureka Server为微服务注册中心。
  Spring Cloud使用注解的方式提供了Eureka服务端(@EnableEurekaServer)和客户端(@EnableEurekaClient)

路由网关

  路由网关的主要目的是为了让所有的微服务对外只有一个接口,我们只需访问一个网关地址,即可由网关将我们的请求代理到不同的服务中。
  Spring Cloud是通过Zuul来实现的,支持自动路由映射到再Eureka Server上注册的服务。Spring Cloud提供了注解@EnableZuulProxy来启用路由代理。

负载均衡

  Spring Cloud 提供了Ribbon和Feign作为客户的负载均衡。在Spring Cloud下,使用Ribbon直接注入一个RestTemplate对象即可,此RestTemplate已做好负载均衡的配置;而使用Feign值需定义个注解,有@FeignClient直接的接口,然后使用@RequestMapping注解在方法上映射远程的REST服务,此方法也是做好负载均衡配置的。

断路器

  断路器(Circuit Breaker),主要是为了解决某个方法调用失败的时候,调用后备方法来替代失败的方法,已达到容错、阻止级联错误等功能。
  Spring Cloud 使用@EnableCircuitBreaker来启动断路器支持,使用@HystrixCommand的fallbackMetthod来指定后备方法。
  Spring Cloud 还给我提供了一个控制台来监控断路器的运行情况。通过@EnableHystrixdDashboard注解开启。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦昼初心

您你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值