【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 ...
随机推荐
- springboot postman 对象里传时间格式问题
主要问题是系列化的问题,在定义时间变量处使用如下的注解即可.导包注意了······ 如果springmvc使用的是com.fasterxml.jackson 的jar包则直接使用一下注解即可 impo ...
- IO流的工具类
1.需要先导入jar包: FilenameUtils import org.apache.commons.io.FilenameUtils; public class FilenameUtilesDe ...
- Tomcat乱码
日志乱码修改logging.properties文件中encoding=UTF-8 vim logging.properties encoding=utf-8 wq!保持退出,重启tomcat 乱码O ...
- 上传本地Jar包到阿里云的云效私有仓库
一.前言 前2天玩了一下上传本地jar到maven中央仓库,随后我们老大又给我说了一个叫云效的私有仓库也可以玩,小编试了一下,果然很舒服,配置很简单,效率很高,几分钟就能搞定,只需要自己有个阿里云的账 ...
- 深入理解Three.js中正交摄像机OrthographicCamera
前言 在深入理解Three.js中透视投影照相机PerspectiveCamera那篇文章中讲解了透视投影摄像机的工作原理以及对应一些参数的解答,那篇文章中也说了会单独讲解Three.js中另一种常用 ...
- SpringBoot启动zipkin-server报错Error creating bean with name ‘armeriaServer’ defined in class path resource
目前,GitHub 上最新 release 版本是 Zipkin 2.12.9,从 2.12.6 版本开始有个较大的更新,迁移使用 Armeria HTTP 引擎. 从此版本开始,若直接添加依赖的 S ...
- 这个注册的 IP 网络都不通了,Eureka 注册中心竟然无法踢掉它!
本文导读: 微服务技术架构选型介绍 k8s 容器化部署架构方案 Eureka 注册中心问题场景 问题解决手段及原理剖析 阅读本文建议先了解: 注册中心基本原理 K8s(Kuberneters)基本概念 ...
- Git初始化项目 和 Gitignore
初始化init: git init git status git add . git commit -am "init projrct" 添加远程仓库: git remote ad ...
- 架构——android架构演进概述
随着业务的发展和技术的变更,Android开发也经历了以下几个发展阶段: 看似高大上的名词,其实遵循着最简单的原则:分而治之(如何划分就是"架构",简单的事情如何串在一起就是&qu ...
- 序列标注(BiLSTM-CRF/Lattice LSTM)
前言 在三大特征提取器中,我们已经接触了LSTM/CNN/Transormer三种特征提取器,这一节我们将介绍如何使用BiLSTM实现序列标注中的命名实体识别任务,以及Lattice-LSTM的模型原 ...