0、项目搭建

创建maven项目,删除其中的src目录,作为整体父项目,在其中添加module实现各个组件。

1、Eureka Server的实现

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka Server依赖,作为Eureka Server。

启动类添加@EnableEurekaServer注释。

修改配置文件application.yml,如下:

 server:
port: 1001 eureka:
client:
//是否将自己注册到eureka server上,默认为true
//由于本节点为eureka server,设为false
registerWithEureka: false
//是否从eureka server获取注册信息,默认为true
//由于为单点的eureka server,不需要同步信息,设为false
fetchRegistry: false
//设置与eureka server交互的地址,查询和注册服务都经过这个地址
serviceUrl:
defaultZone: http://localhost:${server.port}/eureka/

启动项目,即可访问http://localhost:1001/查看eurekaServer管理中心。

2、Service节点

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka Server依赖。

启动类添加@EnableEurekaClient注释(也可用@EnableDiscoveryClient取代,效果相同,前者对应Eureka,后者适用多种注册中心)以及@ComponentScan注释。

修改配置文件application.yml,如下:

 spring:
//服务名称
application:
name: Service1
server:
port: 8001 //在服务中心进行注册
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8801/eureka/

配置完成后启动项目,可在eureka管理中心看到注册的服务。

项目中新建service和controller包,controller包中HelloController负责接受请求,并路由到service包中的具体实现,controller中仅注入service对象,然后根据请求路径调用响应的service实现,service中负责具体的实现。

同理,按上面步骤增加第二个Service节点,注册名为Service2,注册在8002端口。

3、服务调用

Sping  Cloud由两种消费方式,rest+ribbon和feign两种。

3.1、rest+ribbon调用(通过RestTemplate构造URL调用)

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka ServerRibbon依赖。

启动类添加@EnableDiscoveryClient和@ComponentScan注释。

修改配置文件application.yml,注册在8003端口上的Service3服务。

service包和controller包同上。

Service3调用Service1和Service2:

启动类中注入RestTemplate对象,添加@LoadBalance、@Bean和@Autowired注释,开启负载均衡。

改造service包中的具体实现:

自动注入(@Autowired)RestTemplate对象,restTemplate.getForObject("http://${注册应用名}/${请求路径}?参数列表",String.class)

实现远程调用,通过注册应用名自动负载均衡。

3.2、feign调用(通过动态代理的接口来实现接口调用,在接口中实现远程调用)

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka ServerFeign依赖。

启动类添加@EnableDiscoveryClient和@ComponentScan注释。

修改配置文件application.yml,注册在8004端口上的Service4服务。

service包和controller包同上。

Service4调用Service1和Service2:

新增feignRPC包,其中定义两个接口,分别对应两个应用Service1和Service2的调用。

service1_feign接口为:

 @FeignClients(value = "Service1")    //通过应用注册名来调用服务
public interface service1_feign() {
@RequestMapping(value = "/${请求路径}", method = RequestMethod.GET)
public String getHello(@RequestParam("service1中参数名") 具体参数);
}

改造service包中的具体实现:

自动注入(@Autowired)service1_feign接口,像调用本地方法那样调用接口的方法即可实现远程调用

Feign集成了Ribbon,通过注册应用名自动负载均衡。

4、体验负载均衡机制

创建module,普通的service节点,注册在8005端口,应用名为Service1。

在eureka server管理界面可以看到Service1有两个服务提供者提供同名应用。

通过Service3或者Service4调用应用名为Service1的服务。

由于Ribbon默认的负载均衡策略为轮询,通过刷新界面,可以看到一次调用module1和module5提供的服务。

5、网关Zuul的搭建

5.1、体验网关的请求转发功能

创建module,添加Eureka Discovery Client、Eureka Server和Zuul依赖。

启动类添加@EnableZuulProxy注释。

修改配置文件application.yml,注册在6001端口上,注册应用名为zuul。

启动项目后,可以通过网关访问服务:

直接http://localhost:8001/hello?name=world可以访问Service1;

通过网关转发,http://localhost:6001/Service1/hello?name=world访问Service1应用,Zuul默认实现了按应用名负载均衡。

5.2、网关的自定义路由

在application.yml配置文件中配置:

 zuul:
//前缀,请求路径前必须加
prefix: /api
//自定义路由
routes:
Service1: /service_1_zuul/**
//禁止直接访问后台服务
ignored-services: Service1

启动项目后,访问http://localhost:8001/hello?name=world失败,网关禁止直接调用后台服务Service1。

通过网关访问http://localhost:6001/api/service_1_zuul/hello?name=world,可以轮询调用Service1和Service5。

6、Eureka Server集群

7、熔断降级功能

【Spring Cloud】实战项目搭建的更多相关文章

  1. 搭建一套ASP.NET Core+Nacos+Spring Cloud Gateway项目

    前言     伴随着随着微服务概念的不断盛行,与之对应的各种解决方案也层出不穷.这毕竟是一个信息大爆发的时代,各种编程语言大行其道,各有各的优势.但是有一点未曾改变,那就是他们服务的方式,工作的时候各 ...

  2. 3.开始使用Spring Cloud实战微服务

                     开始使用Spring Cloud实战微服务 3.1. Spring Cloud实战前提 3.1.1. 需要的技术储备 语言方面:可以使用Java.scala.Groo ...

  3. spring cloud实战 1-高可用注册中心

    创建父maven项目 提交代码至GitHub 创建eureka-server-1 项目搭建两种方式: 父pom中继承spring-boot-starter-parent,子pom中直接结成父pom.该 ...

  4. 优秀的Spring Cloud开源项目整理推荐

    无论是对于初学者,还是有一定工作经验的程序员来讲,Spring Cloud开源项目都是一笔宝贵的财富.下面给大家整理了十个优秀的开源项目,分别是spring-cloud-examples.spaasc ...

  5. [Spring Cloud实战 | 第六篇:Spring Cloud Gateway+Spring Security OAuth2+JWT实现微服务统一认证授权

    一. 前言 本篇实战案例基于 youlai-mall 项目.项目使用的是当前主流和最新版本的技术和解决方案,自己不会太多华丽的言辞去描述,只希望能勾起大家对编程的一点喜欢.所以有兴趣的朋友可以进入 g ...

  6. Spring Cloud实战 | 最终篇:Spring Cloud Gateway+Spring Security OAuth2集成统一认证授权平台下实现注销使JWT失效方案

    一. 前言 在上一篇文章介绍 youlai-mall 项目中,通过整合Spring Cloud Gateway.Spring Security OAuth2.JWT等技术实现了微服务下统一认证授权平台 ...

  7. Spring Cloud实战 | 最八篇:Spring Cloud +Spring Security OAuth2+ Axios前后端分离模式下无感刷新实现JWT续期

    一. 前言 记得上一篇Spring Cloud的文章关于如何使JWT失效进行了理论结合代码实践的说明,想当然的以为那篇会是基于Spring Cloud统一认证架构系列的最终篇.但关于JWT另外还有一个 ...

  8. Spring Cloud实战 | 第九篇:Spring Cloud整合Spring Security OAuth2认证服务器统一认证自定义异常处理

    本文完整代码下载点击 一. 前言 相信了解过我或者看过我之前的系列文章应该多少知道点我写这些文章包括创建 有来商城youlai-mall 这个项目的目的,想给那些真的想提升自己或者迷茫的人(包括自己- ...

  9. Spring Cloud实战 | 第十篇 :Spring Cloud + Seata 1.4.1 + Nacos1.4.0 整合实现微服务架构中逃不掉的话题分布式事务

    Seata分布式事务在线体验地址:https://www.youlai.store 本篇完整源码地址:https://github.com/hxrui/youlai-mall 有想加入开源项目开发的童 ...

  10. Spring Cloud实战: 基于Spring Cloud Gateway + vue-element-admin 实现的RBAC权限管理系统,实现网关对RESTful接口方法权限和自定义Vue指令对按钮权限的细粒度控制

    一. 前言 信我的哈,明天过年. 这应该是农历年前的关于开源项目 的最后一篇文章了. 有来商城 是基于 Spring Cloud OAuth2 + Spring Cloud Gateway + JWT ...

随机推荐

  1. 从原理到场景 系统讲解 PHP 缓存技术

    第1章课程介绍 此为PHP相关缓存技术的课堂,有哪些主流的缓存技术可以被使用? 第1章 课程介绍 1-1课程介绍1-2布置缓存的目的1-3合理使用缓存1-4哪些环节适合用缓存 第2章 文件类缓存 2- ...

  2. charles 端口转发

    本文参考:charles 端口转发 端口转发 端口转发(Port forwarding),有时被叫做隧道,是安全壳(SSH) 为网络安全通信使用的一种方法.端口转发是转发一个网络端口从一个网络节点到另 ...

  3. [VB.NET Tips]字符串转换为日期

    有些字符串需要转换成日期,或者整型转换为日期,可以参考如下思路: Dim result As Date Dim source As String = "20190515" resu ...

  4. JQuery发送ajax请求时中文乱码

    先排除项目故障: 1.web.xml中是否配置了字符拦截器 <filter> <filter-name>encodingFilter</filter-name> & ...

  5. 关于大脑与CPU的简单思考

    今天午休突发奇想的思考了大脑与cpu的差异,发现出了大脑是生物信号驱动的单核cpu而已(并行任务是时间片的调度,要额外的堆栈记忆或者物理如纸张的存储). 大脑永远是线性的逐行执行指令,执行期间无法判断 ...

  6. 基于Babylon.js编写宇宙飞船模拟程序1——程序基础结构、物理引擎使用、三维罗盘

    计划做一个宇宙飞船模拟程序,首先做一些技术准备. 可以访问https://ljzc002.github.io/test/Spacetest/HTML/PAGE/spacetestwp2.html查看测 ...

  7. 品Spring:对@PostConstruct和@PreDestroy注解的处理方法

    在bean的实例化过程中,也会用到一系列的相关注解. 如@PostConstruct和@PreDestroy用来标记初始化和销毁方法. 平常更多的是侧重于应用,很少会有人去了解它背后发生的事情. 今天 ...

  8. Scala 学习笔记之函数(2)

    class OldStudent extends Student { def filterName(s: String, f: String => String) = { if (s != nu ...

  9. Ionic2优于Ionic1的6个理由

    经历了一个从0到有的app的开发,我已经很熟悉Ionic1了,在此期间我曾发现过Ionic1的一些bug,和一些不合理的地方(根基版本 不同,后续我会陆续发表这些文章),我甚至在此期间对Ionic1进 ...

  10. Mysql Hash索引和B-Tree索引区别(Comparison of B-Tree and Hash Indexes)

    上篇文章中说道,Mysql中的Btree索引和Hash索引的区别,没做展开描述,今天有空,上Mysql官方文档找到了相关答案,看完之后,针对两者的区别做如下总结: 引用维基百科上的描述,来解释一下这两 ...