【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 ...
随机推荐
- List<Object> 多条件去重
上一篇将到根据某一条件去重List<Object> 对象链表.本文章根据多条件去重List<Object>去重 private List<StaingMD0010> ...
- ActiveMQ的安装与使用。
1.什么是ActiveMQ ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE .4规范的 JMS Provider实现,尽 ...
- Mybatis源码解析,一步一步从浅入深(一):创建准备工程
Spring SpringMVC Mybatis(简称ssm)是一个很流行的java web框架,而Mybatis作为ORM 持久层框架,因其灵活简单,深受青睐.而且现在的招聘职位中都要求应试者熟悉M ...
- 【面试必备】小伙伴栽在了JVM的内存分配策略。。。
周末有小伙伴留言说上周面试时被问到内存分配策略的问题,但回答的不够理想,小伙伴说之前公号里看过这一块的文章的,当时看时很清楚,也知道各个策略是干嘛的,但面试时脑子里清楚,心里很明白,但嘴里就是说不清楚 ...
- JSP自定义标签的使用简化版
在jsp中 如果不想页面中出现java代码 这个时候就需要使用到jsp的自定义标签库技术了 自定义标签库 能够有效的减少jsp中java代码的出现 使其更加自然的像html页面一样 如果要使用jsp自 ...
- Git初始化项目 和 Gitignore
初始化init: git init git status git add . git commit -am "init projrct" 添加远程仓库: git remote ad ...
- python打开文件查询字符串时报UnicodeDecodeError: 'gbk' codec can't decode byte 0xaa in position 19: illegal multibyte sequence错误
当这样打开时报错了 lines = open(path).readlines() open(path).close() for line in lines: idx1 = line.find('检测到 ...
- Spring MVC-从零开始-如何访问静态资源
转(Spring MVC静态资源处理) 优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置Dis ...
- redis分布式锁-基本概念与实现方式对比
1.redis中使用WATCH实现锁机制,是最次之的方式.WATCH只会在数据被其他客户端抢先修改了的情况下,“通知”执行了这个命令的客户端,而不会阻止其他客户端对数据进行修改.此类锁成为“乐观锁” ...
- 命名对象继承1-验证Create*命名对象安全属性的传递
windows核心编程 第5版 48页 下半部写道 进程B调用CreateMutex时,它会向函数传递安全属性信息和第二参数.如果已经存在一个指定名称的对象,这些对象就会被忽略 于是我通过代码来验证这 ...