开发者学堂课程干货总结——Spring Cloud微服务架构设计与开发实战(十九)

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: Spring Cloud微服务架构设计与开发实战课时2.8—Java Spring Cloud网关Zuul 。Java Spring Cloud是全球范围内最成熟、最完善、最流行的微服务架构方案体系。被众多的互联网大公司采用,包括阿里巴巴、腾讯、支付宝、网易、IBM、谷歌、京东、百度、滴滴等。电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦!

哈喽各位同学们大家好呀,今天是开发者学院中课程“Spring Cloud微服务架构设计与开发实战”的章节二的Java Spring Cloud网关Zuul ”干货总结~是一起学习新课程吧!

课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇

课程名称:Java Spring Cloud网关Zuul

课程地址:https://developer.aliyun.com/learning/course/60/detail/1091

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java


Java Spring Cloud网关Zuul


一、Java Spring Cloud网关Zuul 

本节课讲的是微服务架构非常重要的技术“Zuul网关”,现在已经迭代到2.0版本,架构底层也发生了较大的变化。微服务集群为什么需要网关,因为服务特别多,尤其是对外的时候,作为调用端,不可能知道每台服务的实例地址,中间有注册心,实例地址会动态变化,所以希望有统一的出口,这就是网关的作用。 

网关是两个网络边界的通道,相当于请求转发,就是代理服务器。 

(一)Spring CloudZuul网关 

Zuul是Netflix开源的微服务网关工具Netflix公司微服务领域贡献了早期的核心代码,当然2020年之后Zuul,包括其他的一些Spring Cloud的组件,主要在维护阶段与Spring Cloud官方产生了分歧,但是仍然可以使用,而且功能也比较完善,包括实名验证、日志、路由定制等功能。2.0版本的功能更加强大,因为后面考虑优化,比如连接池等相关功能的扩展。 

Spring Cloud官方也出了类似ZuulGateway技术,Gateway技术基于Spring Framework 5 底层框架实现的,吞吐量方面有比较高的提升。但是使用场景要看实际情况,绝大部分公司的并发都不会超过1000很少有超过10000万的公司,因为中国互联网公司不是各个都是BAT, 所以会有差异。 

Spring CloudZuul网关总结: 

1. Zuul是Netflix开源的微服务网关工具 

2. 可以和Eureka、Ribbon、Hystrix等组件配合使用 

3. Spring Cloud对Zuul进行了整合与增强, 

4. Zuul旨在实现动态路由,监视,弹性和安全性。 

5. Zuul默认使用的HTTP客户端是Apache HTTPClient 

6. 也可以使用RestClient或okhttp3.OkHttpClient 

7. Zuul默认会为Eureka注册的服务创建动态路由 

8. zuul在2.x甚至3.x的分支中已经引入了netty 

9. github地址:https://github.com/Netflix/zuul 

10.官方文档:https://github.com/Netflix/zuul/wiki 

(二)Spring Cloud Zuul网关架构 

网关做为代理,后面挂接微服务集群,熔断、监控、身份验证等都可以放在代理做,Zuul出口对外可以做微服务代理模式,前面可以连接移动APP等,后面数据设计,有一种模式叫一个微服务一个数据库,还有现在国内还比较流行分库分表,有没有把数据库拆开,要不要把数据库拆开以后再分表。这个问题变得越来越复杂,不同的公司不同的业务量,规模都会有差别。 

当然好处是里面的组件都可以替换,不会出现多个相同组件,比如注册中心,可以替换成阿里开源的,国内很多人喜欢阿里的技术。阿里在Java块是国内贡献最大的一个公司如果阿里不在淘宝使用Java有可能Java在国内没有这么大市场架构不会得到如此广泛的实践性验证。现在无论是 Spring Clord 还是 Dubbo技术,都是很好的技术型。 

image.png 

 

(三)Zuul网关特性 

Zuul首先是作为代理层作为网关,路由、负载均衡、日志等都是扩展功能,主要的作用是把请求转发过去。 

1. Authentication and Security –验证和安全 

2. Insights and Monitoring –跟踪、统计、监控 

3. Dynamic Routing –动态路由 消息到 后台集群 

4. Stress Testing – 压力测试 逐级递增 

5. Load Shedding –过载保护 

6. Static Response handling – 静态消息处理,无需后台集群服务器处理 

7. Multiregion Resiliency – 多区域弹性伸缩,跨AWS区域路由请求,分散压力,请求处理更接近调用者。 

 

二、Spring Cloud网关Zuul实战 

(一)创建Zuul代理 

首先引入Zuul的依赖包,其次需要和注册中心进行交互,要知道那些服务可用,来代理可用的服务,是微服务集群的统一入口。 

 首先创建一个Spring Boot项目, 

 然后引入Zuul相关依赖。 

 <dependency> 

 <groupId>org.springframework.cloud</groupId> 

<artifactId> spring-cloud-starter-zuul</artifactId> 

 </dependency> 

 <dependency> 

 <groupId>org.springframework.cloud</groupId> 

<artifactId> spring-cloud-starter-eureka</artifactId> 

</dependency> 

 添加注解@EnableZuulProxy;  

 Zuul内部使用Ribbon实现客户端负载均衡。 

(二)EnableZuulServer 

为了方便启动微服代理应用,Zuul提供了EnableZuulProxy 的快速注解,里面有组件默认的集成,直接在POS里实现。 

 @EnableZuulServer只启动代理服务 

 @EnableZuulProxy简单理解为@EnableZuulServer的增强版, 

 Zuul与Eureka、Ribbon等组件配合使用时, 

 使用@EnableZuulProxy 

(三)Spring Cloud Zuul网关底层优化 

1. RestClient或okhttp3.OkHttpClient 

2. Zuul默认会为Eureka注册的服务创建动态路由 

3. zuul在2.x甚至3.x的分支中已经引入了netty 

 

实战演示 

之前做的项目不动,里面有微服务、注册中心、调用端。打开Eclipse开发工具,新建项目,Name栏直接加上:ZoolProxyDemo 

image.png 

下一步,Frequently Used:选上Eurka Discovery ClieSpring Boot DevtoolsZuul[Mainternance],版本选2.3.7 

image.png 

下一步,直接上线 

image.png 

稍等,会有一个构建过程,下一步加注解,@EnableZuulProxy。注意中间不能中断,包一旦出错很难找回。 

image.png 

 

因为Zuul配置和调用端很像,直接复制调用端的配置改成ZuulName=ZuulProxy,端口=1000,详情配置如下图所示: 

image.png 

默认连接注册中心以后,会把所有的服务列表全部拉过来,默认形成一个路由策略会基于服务名方法名来形成一个路由规则,当然用户也可以改路由规则,可以定制,也可以改配置。暂时这里不改,后面作为扩展学习的时候再深入讲。 

接下来启动程序,直接右键,选Run As ,有两种启动方式,1.jave Application,2.Spring Boot APP,两种都可以启动。 

image.png 

启动成功之后,打开浏览器,输入http://localhost:10000/order-microservice/hello 回车,显示已经调用成功。 

image.png 

 

看一下访问规则,端口是:10000;服务端是:hello; 注册中心是:order-microservice。现在的路由规则是基于服务名和方法名调用。 

image.png 

 

通过代理服务器网关),输入服务名字方法名就可以了。当然也可以定制特殊的规则,这节课不演示。做演示会比较简单,主要是把整个调用链跑通,告诉大家整个微服务架构的搭建过程。 

 

相关文章
|
1月前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
165 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
63 4
|
8天前
|
存储 JavaScript 开发工具
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
本次的.HarmonyOS Next ,ArkTS语言,HarmonyOS的元服务和DevEco Studio 开发工具,为开发者提供了构建现代化、轻量化、高性能应用的便捷方式。这些技术和工具将帮助开发者更好地适应未来的智能设备和服务提供方式。
33 8
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
|
14天前
|
人工智能 前端开发 Java
Spring AI Alibaba + 通义千问,开发AI应用如此简单!!!
本文介绍了如何使用Spring AI Alibaba开发一个简单的AI对话应用。通过引入`spring-ai-alibaba-starter`依赖和配置API密钥,结合Spring Boot项目,只需几行代码即可实现与AI模型的交互。具体步骤包括创建Spring Boot项目、编写Controller处理对话请求以及前端页面展示对话内容。此外,文章还介绍了如何通过添加对话记忆功能,使AI能够理解上下文并进行连贯对话。最后,总结了Spring AI为Java开发者带来的便利,简化了AI应用的开发流程。
223 0
|
21天前
|
XML JSON Java
Spring Boot 开发中常见的错误
本文总结了 Java 开发中常见的几个问题及其改进方法,包括:1. 过度使用 `@Component` 注解;2. `@ResponseBody` 注解的错误用法;3. `@Autowired` 的不当使用;4. `application.properties` 管理不善;5. 异常处理不当。每部分详细解释了错误情况和建议的改进方案,并提供了相应的代码示例。
47 11
|
15天前
|
运维 监控 Java
为何内存不够用?微服务改造启动多个Spring Boot的陷阱与解决方案
本文记录并复盘了生产环境中Spring Boot应用内存占用过高的问题及解决过程。系统上线初期运行正常,但随着业务量上升,多个Spring Boot应用共占用了64G内存中的大部分,导致应用假死。通过jps和jmap工具排查发现,原因是运维人员未设置JVM参数,导致默认配置下每个应用占用近12G内存。最终通过调整JVM参数、优化堆内存大小等措施解决了问题。建议在生产环境中合理设置JVM参数,避免资源浪费和性能问题。
42 3
|
21天前
|
IDE Java 测试技术
互联网应用主流框架整合之Spring Boot开发
通过本文的介绍,我们详细探讨了Spring Boot开发的核心概念和实践方法,包括项目结构、数据访问层、服务层、控制层、配置管理、单元测试以及部署与运行。Spring Boot通过简化配置和强大的生态系统,使得互联网应用的开发更加高效和可靠。希望本文能够帮助开发者快速掌握Spring Boot,并在实际项目中灵活应用。
38 5
|
19天前
|
前端开发 Java 开发者
这款免费 IDEA 插件让你开发 Spring 程序更简单
Feign-Helper 是一款支持 Spring 框架的 IDEA 免费插件,提供 URL 快速搜索、Spring Web Controller 路径一键复制及 Feign 与 Controller 接口互相导航等功能,极大提升了开发效率。
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
141 5
|
2月前
|
前端开发 JavaScript Java
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
如何使用 Spring Boot 和 Angular 开发全栈应用程序:全面指南
51 1