Spring Cloud 微服务网关代理 Zuul| 学习笔记

简介: 快速学习 Spring Cloud 微服务网关代理 Zuul。

开发者学堂课程【Spring Cloud 微服务架构设计与开发实战 Spring Cloud 微服务网关代理 Zuul】学习笔记,与课程紧密联系,让用户快速学习知识。

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


Spring Cloud 微服务网关代理 Zuul

 

内容介绍

一、微服务网关 Zuul

二、微服务网关架构

三、Zuul 网关特性

四、微服务网关 Zuul 实战

 

课程概要:学习 Spring Cloud 微服务架构设计与实战课程,本课继续学习微服务架构中非常重要的技术-网关,迭代版本很快,架构体发生巨大变化,接下来我们来学习其原理

 

一、微服务网关 Zuul

对外公开服务特别多,就需要使用网关,网关本身是两个网络边界的通道,严格来说相当于请求转换,即代理服务器。

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

Netflix 共享在早期的核心代码,学习资料还可以使用,基于 SpringBoot ,基于 SpringCloud 都可以使用,做识别认证和安全都可以,在吞吐量有很高的提升。

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

 

二、微服务网关架构

image.png

代理端作为网关后期是挂接微服务集群,监控也是一致的,监控整个后台服务调用,现在的监控可以放到代理商来做,出口对外可以作微服务的代理对外模式。

一个微服务一个数据库,拆开数据库分表问题会越来越复杂,但是可以替换,好处在于数据中心可以替换。

 

三、Zuul 网关特性

1. Authentication and Security-验证和安全

2. 2.Insights and Monitoring-踉踪、统计、监控.

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

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

5.Load Shedding -过载保护.

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

7.Multiregion Resiliency - 多区域弹性伸缩,跨 AWS 区域路由

请求,分散压力,请求处理更接近调用者。

 

四、微服务网关 zuul 实战

1. 创建 Zuul 代理

(1)首先创建一个 Spring Boot 项目,然后引入 Zuul 相关依赖。

<dependency>

<groupld>org.springframework.cloud</groupld>

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

</dependency>

<dependency>

<groupld>org.springframework.cloud</groupld>

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

</dependency>

(2)添加注解@EnableZuulProxy

(3)Zuul 丙部使用 Ribbon 实现客户端负载均衡。

2.EnableZuulServer

提供为了方便启用微服务代理应用:

EnableZuulServer 只启动代理服务

EnableZuulProxy 简单理解内 @EnableZuuIserve 的增强版

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

使用 @EnableZuulProxy。

新建一个项目

最主要的是添加注解:

package com.alibaba;

import org.springframework.boot.SpringApplication;

@EnableZuulProxy

@SpringBootApplication

Publicclass

JavaSpringCloud000000zuulProxyDemoApplication {

public static void main(String[ ] args ) {

SpringApplication.run(

JavaSpringCloud000000ZuulProxyDemoAppl:

}

}

参考调用端,将端口修改即可:

spring.application.name=FeignClient

server.port=10000

eureka.client.service-url.defaultZone=http://localhost:8761/eureka/eureka.client.fetch-registry=true

eureka.client.register-with-eureka=true

默认链接会拉去所有的服务器设备,可定制

运行结果:

image.png

image.png

访问端口10000,运行结果:

image.png

报错

注意大小写敏感:

image.png

相关文章
|
7月前
|
算法 Java 微服务
【SpringCloud(1)】初识微服务架构:创建一个简单的微服务;java与Spring与微服务;初入RestTemplate
微服务架构是What?? 微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。 每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。 每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
664 126
|
7月前
|
负载均衡 算法 Java
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
1. 什么是服务治理? SpringCloud封装了Netfix开发的Eureka模块来实现服务治理 在传统pc的远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册
433 0
|
8月前
|
数据可视化 Java BI
将 Spring 微服务与 BI 工具集成:最佳实践
本文探讨了 Spring 微服务与商业智能(BI)工具集成的潜力与实践。随着微服务架构和数据分析需求的增长,Spring Boot 和 Spring Cloud 提供了构建可扩展、弹性服务的框架,而 BI 工具则增强了数据可视化与实时分析能力。文章介绍了 Spring 微服务的核心概念、BI 工具在企业中的作用,并深入分析了两者集成带来的优势,如实时数据处理、个性化报告、数据聚合与安全保障。同时,文中还总结了集成过程中的最佳实践,包括事件驱动架构、集中配置管理、数据安全控制、模块化设计与持续优化策略,旨在帮助企业构建高效、智能的数据驱动系统。
420 1
将 Spring 微服务与 BI 工具集成:最佳实践
|
8月前
|
存储 安全 Java
管理 Spring 微服务中的分布式会话
在微服务架构中,管理分布式会话是确保用户体验一致性和系统可扩展性的关键挑战。本文探讨了在 Spring 框架下实现分布式会话管理的多种方法,包括集中式会话存储和客户端会话存储(如 Cookie),并分析了它们的优缺点。同时,文章还涵盖了与分布式会话相关的安全考虑,如数据加密、令牌验证、安全 Cookie 政策以及服务间身份验证。此外,文中强调了分布式会话在提升系统可扩展性、增强可用性、实现数据一致性及优化资源利用方面的显著优势。通过合理选择会话管理策略,结合 Spring 提供的强大工具,开发人员可以在保证系统鲁棒性的同时,提供无缝的用户体验。
185 0
|
8月前
|
消息中间件 Java 数据库
Spring 微服务中的数据一致性:最终一致性与强一致性
本文探讨了在Spring微服务中实现数据一致性的策略,重点分析了最终一致性和强一致性的定义、优缺点及适用场景。结合Spring Boot与Spring Cloud框架,介绍了如何根据业务需求选择合适的一致性模型,并提供了实现建议,帮助开发者在分布式系统中确保数据的可靠性与同步性。
557 0
|
7月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
1279 2
Spring Boot 3.x 微服务架构实战指南
|
7月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
8月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
513 1
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
5318 2