热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

11微服务网关(一)概念介绍Zuul简单入门

11.1服务网关的概念11.1.1什么是微服务网关11.1.2作用和应用场景11.2常见的API网关实现方式11.3基于Nginx的网关实现IP地址映射到路径,统一

11.1 服务网关的概念


11.1.1 什么是微服务网关

11.1.2作用和应用场景

 

11.2 常见的API网关实现方式

11.3 基于Nginx的网关实现

IP地址映射到路径,统一管理

11.4 Zuul网关


11.4.1 Zuul简介

 11.4.2 搭建Zuul微服务网关

  1 创建工程导入依赖

org.springframework.cloudspring-cloud-starter-netflix-zuul

  2 配置启动类,开启网关服务器功能

package xx.study.sc;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;@SpringBootApplication
//开启zuul网关功能
@EnableZuulProxy
public class ZuulServerApplication {public static void main(String[] args) {SpringApplication.run(ZuulServerApplication.class);}
}

  3 配置文件

server.port=8080
spring.application.name=api-zuul-server

11.4.3 路由

路由:根据请求的URl匹配到不同的微服务

1 基础路由配置

#路由配置
#product-service路由id 随便写;/product-service/** 映射路径 localhost:8080/product-service/xxxx
zuul.routes.product-service.path=/product-service/**
#映射路径对应的实际微服务地址 http://localhost:8080/product-service/product/buy?name=apple
zuul.routes.product-service.url=http://127.0.0.1:9001

 2 面向服务的路由

 

a  添加eureka的依赖

org.springframework.cloudspring-cloud-starter-netflix-zuulorg.springframework.cloudspring-cloud-starter-netflix-eureka-client

b  开启eureka的客户端发现

package xx.study.sc;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;@SpringBootApplication
//开启zuul网关功能
@EnableZuulProxy
@EnableEurekaClient
public class ZuulServerApplication {public static void main(String[] args) {SpringApplication.run(ZuulServerApplication.class);}
}

c 在zuul网关服务中配置eureka的注册中心相关信息

#注册中心访问地址
eureka.client.service-url.defaultZone=http://localhost:8000/eureka/

d 修改路由中的映射路径


#product-service路由id 随便写;/product-service/** 映射路径 localhost:8080/product-service/xxxx
zuul.routes.product-service.path=/product-service/**
#映射路径对应的实际微服务地址
#zuul.routes.product-service.url=http://127.0.0.1:9001
#配置转发的微服务名称
zuul.routes.product-service.service-id=service-product

3 简化配置

#简化配置
# 如果路由id和服务名称一致的话可进行如下配置
zuul.routes.service-product=/product-service/**
#zuul的默认路由 不用配置可直接访问注册中心的服务 如果当前服务名称service-product 默认的请求映射路径 /service-product/**

11.4.4 Zuul加入后的架构

11.5 Zuul 过滤器

11.5.1 ZuulFilter 简介

11.5.2 过滤器访问流程

11.5.3 过滤器的实现

package xx.study.sc.fitter;import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.exception.ZuulException;
import org.springframework.stereotype.Component;@Component
public class LoginFilter extends ZuulFilter {/*** 定义过滤器类型* pre 转发到微服务之前执行的过滤器* routing* post* error* @return*/public String filterType() {return "pre";}/*** 指定过滤器的执行顺序 返回值越小 执行顺序越高* @return*/public int filterOrder() {return 1;}/*** 当前过滤器是否生肖* true :生效* @return*/public boolean shouldFilter() {return true;}/*** 指定过滤器的业务逻辑* @return* @throws ZuulException*/public Object run() throws ZuulException {System.out.println("进入过滤器了!!!");return null;}
}

11.5.4 案例用户登录

简单代码实现

package xx.study.sc.fitter;import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.apache.http.HttpStatus;
import org.springframework.stereotype.Component;import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;@Component
public class LoginFilter extends ZuulFilter {/*** 定义过滤器类型* pre 转发到微服务之前执行的过滤器* routing* post* error* @return*/public String filterType() {return "pre";}/*** 指定过滤器的执行顺序 返回值越小 执行顺序越高* @return*/public int filterOrder() {return 1;}/*** 当前过滤器是否生肖* true :生效* @return*/public boolean shouldFilter() {return true;}/*** 指定过滤器的业务逻辑* 身份验证* 1 所有的请求需要携带一个参数 access-token* 2 获取request请求* 3 通过request 获取参数access-token* 4 判断token是否为空* 4.1 token==null 身份验证失败* 4.2 token!=null 执行后续操作* 在Zuul网关中,通过RequestContext的上下文对象,可以获取对象request对像** @return* @throws ZuulException*/public Object run() throws ZuulException {//System.out.println("进入过滤器了!!!");RequestContext ctx=RequestContext.getCurrentContext();HttpServletRequest requst=ctx.getRequest();String token=requst.getParameter("access-token");if (token==null){ctx.setSendZuulResponse(false);//拦截请求ctx.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);}return null;//返回null 继续运行}
}

11.6内部源码

 

11.7 Zuul网关存在问题

11.8 Zuul替换方案

Zuul2.x版本  SpringCloud不支持;

SpringCloud Gateway  可以替换,后续讲解。

 


推荐阅读
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 利用GitHub热门资源,成功斩获阿里、京东、腾讯三巨头Offer
    Spring框架作为Java生态系统中的重要组成部分,因其强大的功能和灵活的扩展性,被广泛应用于各种规模的企业级应用开发中。本文将通过一份在GitHub上获得极高评价的Spring全家桶文档,探讨如何掌握Spring框架及其相关技术,助力职业发展。 ... [详细]
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • Spring Boot单元测试中Redis连接失败的解决方案
    本文探讨了在Spring Boot项目中进行单元测试时遇到Redis连接问题的原因及解决方法,详细分析了配置文件加载路径不当导致的问题,并提供了有效的解决方案。 ... [详细]
  • 深入解析Spring Cloud微服务架构与分布式系统实战
    本文详细介绍了Spring Cloud在微服务架构和分布式系统中的应用,结合实际案例和最新技术,帮助读者全面掌握微服务的实现与优化。 ... [详细]
  • Spring Cloud学习指南:深入理解微服务架构
    本文介绍了微服务架构的基本概念及其在Spring Cloud中的实现。讨论了微服务架构的主要优势,如简化开发和维护、快速启动、灵活的技术栈选择以及按需扩展的能力。同时,也探讨了微服务架构面临的挑战,包括较高的运维要求、分布式系统的复杂性、接口调整的成本等问题。最后,文章提出了实施微服务时应遵循的设计原则。 ... [详细]
  • Spring Cloud因其强大的功能和灵活性,被誉为开发分布式系统的‘一站式’解决方案。它不仅简化了分布式系统中的常见模式实现,还被广泛应用于企业级生产环境中。本书内容详实,覆盖了从微服务基础到Spring Cloud的高级应用,适合各层次的开发者。 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 深入解析:阿里实战 SpringCloud 微服务架构与应用
    本文将详细介绍 SpringCloud 在微服务架构中的应用,涵盖入门、实战和案例分析。通过丰富的代码示例和实际项目经验,帮助读者全面掌握 SpringCloud 的核心技术和最佳实践。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 本文介绍了如何利用 Spring Boot 和 Groovy 构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
author-avatar
wgol992015
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有