【Spring Cloud】实战项目搭建
0、项目搭建
创建maven项目,删除其中的src目录,作为整体父项目,在其中添加module实现各个组件。
1、Eureka Server的实现
添加module,创建Spring Boot项目,添加Eureka Discovery Client和Eureka 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 Client和Eureka 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 Client、Eureka Server和Ribbon依赖。
启动类添加@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 Client、Eureka Server和Feign依赖。
启动类添加@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】实战项目搭建的更多相关文章
- 搭建一套ASP.NET Core+Nacos+Spring Cloud Gateway项目
前言 伴随着随着微服务概念的不断盛行,与之对应的各种解决方案也层出不穷.这毕竟是一个信息大爆发的时代,各种编程语言大行其道,各有各的优势.但是有一点未曾改变,那就是他们服务的方式,工作的时候各 ...
- 3.开始使用Spring Cloud实战微服务
开始使用Spring Cloud实战微服务 3.1. Spring Cloud实战前提 3.1.1. 需要的技术储备 语言方面:可以使用Java.scala.Groo ...
- spring cloud实战 1-高可用注册中心
创建父maven项目 提交代码至GitHub 创建eureka-server-1 项目搭建两种方式: 父pom中继承spring-boot-starter-parent,子pom中直接结成父pom.该 ...
- 优秀的Spring Cloud开源项目整理推荐
无论是对于初学者,还是有一定工作经验的程序员来讲,Spring Cloud开源项目都是一笔宝贵的财富.下面给大家整理了十个优秀的开源项目,分别是spring-cloud-examples.spaasc ...
- [Spring Cloud实战 | 第六篇:Spring Cloud Gateway+Spring Security OAuth2+JWT实现微服务统一认证授权
一. 前言 本篇实战案例基于 youlai-mall 项目.项目使用的是当前主流和最新版本的技术和解决方案,自己不会太多华丽的言辞去描述,只希望能勾起大家对编程的一点喜欢.所以有兴趣的朋友可以进入 g ...
- Spring Cloud实战 | 最终篇:Spring Cloud Gateway+Spring Security OAuth2集成统一认证授权平台下实现注销使JWT失效方案
一. 前言 在上一篇文章介绍 youlai-mall 项目中,通过整合Spring Cloud Gateway.Spring Security OAuth2.JWT等技术实现了微服务下统一认证授权平台 ...
- Spring Cloud实战 | 最八篇:Spring Cloud +Spring Security OAuth2+ Axios前后端分离模式下无感刷新实现JWT续期
一. 前言 记得上一篇Spring Cloud的文章关于如何使JWT失效进行了理论结合代码实践的说明,想当然的以为那篇会是基于Spring Cloud统一认证架构系列的最终篇.但关于JWT另外还有一个 ...
- Spring Cloud实战 | 第九篇:Spring Cloud整合Spring Security OAuth2认证服务器统一认证自定义异常处理
本文完整代码下载点击 一. 前言 相信了解过我或者看过我之前的系列文章应该多少知道点我写这些文章包括创建 有来商城youlai-mall 这个项目的目的,想给那些真的想提升自己或者迷茫的人(包括自己- ...
- Spring Cloud实战 | 第十篇 :Spring Cloud + Seata 1.4.1 + Nacos1.4.0 整合实现微服务架构中逃不掉的话题分布式事务
Seata分布式事务在线体验地址:https://www.youlai.store 本篇完整源码地址:https://github.com/hxrui/youlai-mall 有想加入开源项目开发的童 ...
- Spring Cloud实战: 基于Spring Cloud Gateway + vue-element-admin 实现的RBAC权限管理系统,实现网关对RESTful接口方法权限和自定义Vue指令对按钮权限的细粒度控制
一. 前言 信我的哈,明天过年. 这应该是农历年前的关于开源项目 的最后一篇文章了. 有来商城 是基于 Spring Cloud OAuth2 + Spring Cloud Gateway + JWT ...
随机推荐
- IBM DB2 SQL error code list
SQL return codes that are preceded by a minus sign (-) indicate that the SQL statement execution was ...
- Kubernetes 从懵圈到熟练:集群服务的三个要点和一种实现
作者 | 声东 阿里云售后技术专家 文章来源:Docker,点击查看原文. 以我的经验来讲,理解 Kubernetes 集群服务的概念,是比较不容易的一件事情.尤其是当我们基于似是而非的理解,去排查服 ...
- 脱离脚手架来配置、学习 webpack4.x (二)基础搭建loader 配置 css、scss
序 上一篇已经把基本架子搭起来了,现在来增加css.scss.自动生成html.css 提前等方面的打包.webpack 默认只能处理js模块,所以其他文件类型需要做下转换,而loader 恰恰是做这 ...
- Moonraker 靶机渗透
0x01 简介 攻击Moonraker系统并且找出存在最大的威胁漏洞,通过最大威胁漏洞攻击目标靶机系统并进行提权获取系统中root目录下的flag信息. Moonraker: 1镜像下载地址: htt ...
- vue-router路由元信息及keep-alive组件级缓存
路由元信息?(黑人问号脸???)是不是这么官方的解释很多人都会一脸懵?那么我们说meta,是不是很多人恍然大悟,因为在项目中用到或者看到过呢? 是的,路由元信息就是我们定义路由时配置的meta字段:那 ...
- python库之turtle(图形绘制) 开启新的快乐源泉
相信有不少人学习python 都是听了老前辈的推荐 “学python好,python有趣的代码多” 比如说画一只小狮子 这就是今天想要介绍的绘制图形库-turtle 如果也想这样画一只小狮子,或者其他 ...
- Java Map知识点
1.遍历 java遍历Map的方式有多种,一下以代码示例来说明使用: Map<String, String> tmap = new HashMap<String, String> ...
- freemarker常用属性
1.th:action 定义后台控制器的路径,类似<form>标签的action属性. 示例如下. <form id="login" th:action=&quo ...
- python线程实现异步任务
了解异步编程 楼主在工作中遇到了以下问题,开发接口爬取数据代码完成之后要写入redis缓存,但是在写入缓存的过程花费2-3s,进行这样就大大影响了接口的性能,于是想到了使用异步存储. 传统的同步编程是 ...
- 快学Scala 第五课 (构造映射,获取映射值,更新映射值,迭代映射,与Java互操作)
构造映射: val score = Map[String, Int]() val score1 = HashMap[String, Int]() val value1 = Map[String, In ...