广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >浅析getway网关
  • 294
分享到

浅析getway网关

2024-04-02 19:04:59 294人浏览 安东尼
摘要

目录一、网关基本概念1、api网关介绍2、spring cloud Gateway3、spring Cloud Gateway核心概念二、getway网关例子1、在infrastru

一、网关基本概念

1、API网关介绍

API网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题:

(1)客户端会多次请求不同的微服务,增加了客户端的复杂性。

(2)存在跨域请求,在一定场景下处理相对复杂。

(3)认证复杂,每个服务都需要独立认证。

(4)难以重构,随着项目的迭代,可能需要重新划分微服务。例如,可能将多个服务合并成一个或者将一个服务拆分成多个。如果客户端直接与微服务通信,那么重构将会很难实施。

(5)某些微服务可能使用了防火墙/浏览器不友好的协议,直接访问会有一定的困难。

以上这些问题可以借助API网关解决。API网关是介于客户端和服务器端之间的中间层,所有的外部请求都会先经过API网关这一层。也就是说,API的实现方面更多的考虑业务逻辑,而安全、性能、监控可以交由API网关来做,这样既提高业务灵活性又不缺安全性

(6)getway可以实现Nginx的请求转发和跨域(@CrossOrigin也可以实现跨域)。

负载均衡:把请求平均分配到多台服务器上。集群部署,部署2台service-edu服务,只有端口号不同,项目都一样。

2、Spring Cloud Gateway

Spring cloud gateway是spring官方基于Spring 5.0、Spring Boot2.0和Project Reactor等技术开发的网关,Spring Cloud Gateway旨在为微服务架构提供简单、有效和统一的API路由管理方式,Spring Cloud Gateway作为Spring Cloud生态系统中的网关,目标是替代Netflix Zuul,其不仅提供统一的路由方式,并且还基于Filer链的方式提供了网关基本的功能,例如:安全、监控/埋点、限流等。

网关和服务都在Nacos注册,注册之后通过Getway网关在访问相应的服务

3、Spring Cloud Gateway核心概念

网关提供API全托管服务,丰富的API管理功能,辅助企业管理大规模的API,以降低管理成本和安全风险,包括协议适配、协议转发、安全策略、防刷、流量、监控日志等贡呢。一般来说网关对外暴露的URL或者接口信息,我们统称为路由信息。如果研发过网关中间件或者使用过Zuul的人,会知道网关的核心是Filter以及Filter Chain(Filter责任链)。Sprig Cloud Gateway也具有路由和Filter的概念。下面介绍一下Spring Cloud Gateway中几个重要的概念。

(1)路由。路由是网关最基础的部分,路由信息有一个ID、一个目的URL、一组断言和一组Filter组成。如果断言路由为真,则说明请求的URL和配置匹配

(2)断言。Java8中的断言函数。Spring Cloud Gateway中的断言函数输入类型是Spring5.0框架中的ServerWEBExchange。Spring Cloud Gateway中的断言函数允许开发者去定义匹配来自于Http request中的任何信息,比如请求头和参数等,简单来讲就是一个匹配规则,如果匹配到就到Handler去处理。

(3)过滤器。一个标准的Spring webFilter。Spring cloud gateway中的filter分为两种类型的Filter,分别是Gateway Filter和Global Filter。过滤器Filter将会对请求和响应进行修改处理,统一异常处理,统一跨域处理等。

如上图所示,Spring cloud Gateway发出请求。然后再由Gateway Handler Mapping中找到与请求相匹配的路由,将其发送到Gateway web handler。Handler再通过指定的过滤器链将请求发送到我们实际的服务执行业务逻辑,然后返回。

二、getway网关例子

1、在infrastructure模块下创建api_gateway模块

2、在pom.xml引入依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://Maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>infrastructure</artifactId>
        <groupId>com.stu</groupId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>api_gateway</artifactId>
    <dependencies>
        <dependency>
            <groupId>com.stu</groupId>
            <artifactId>common-utils</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <!--gson-->
        <dependency>
            <groupId>com.Google.code.gson</groupId>
            <artifactId>gson</artifactId>
        </dependency>

        <!--服务调用-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
    </dependencies>

</project>

3、编写application.properties配置文件

# 服务端口
server.port=8222
# 服务名
spring.application.name=service-gateway
# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
#使用服务发现路由,通过openfeign找到服务(nginx是通过配置文件的路径匹配发现服务)
spring.cloud.gateway.discovery.locator.enabled=true
#服务路由名小写
#spring.cloud.gateway.discovery.locator.lower-case-service-id=true
#配置service-edu服务
#设置路由id(id可以随便命名,建议用服务名称)
spring.cloud.gateway.routes[0].id=service-edu
#设置路由的uri
spring.cloud.gateway.routes[0].uri=lb://service-edu
#设置路由断言,代理servicerId为auth-service的/auth/路径
spring.cloud.gateway.routes[0].predicates= Path=/eduserviceacl
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.reactive.CorsWebFilter;
import org.springframework.web.cors.reactive.UrlBasedCorsConfigurationSource;
import org.springframework.web.util.pattern.PathPatternParser;

@Configuration
public class CorsConfig {
    @Bean
    public CorsWebFilter corsFilter() {
        CorsConfiguration config = new CorsConfiguration();
        config.addAllowedMethod("*");
        config.addAllowedOrigin("*");
        config.addAllowedHeader("*");
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser());
        source.reGISterCorsConfiguration("
@Component
public class AuthGlobalFilter implements GlobalFilter, Ordered {
    private AntPathMatcher antPathMatcher = new AntPathMatcher();
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        ServerHttpRequest request = exchange.getRequest();
        String path = request.getURI().getPath();
        //校验用户必须登录
        if(antPathMatcher.match("/apiauthinner
@Configuration
@EnableConfigurationProperties({ServerProperties.class, ResourceProperties.class})
public class ErrorHandlerConfig {
    private final ServerProperties serverProperties;
    private final ApplicationContext applicationContext;
    private final ResourceProperties resourceProperties;
    private final List<ViewResolver> viewResolvers;
    private final ServerCodecConfigurer serverCodecConfigurer;
    public ErrorHandlerConfig(ServerProperties serverProperties,
                                     ResourceProperties resourceProperties,
                                     ObjectProvider<List<ViewResolver>> viewResolversProvider,
                                        ServerCodecConfigurer serverCodecConfigurer,
                                     ApplicationContext applicationContext) {
        this.serverProperties = serverProperties;
        this.applicationContext = applicationContext;
        this.resourceProperties = resourceProperties;
        this.viewResolvers = viewResolversProvider.getIfAvailable(Collections::emptyList);
        this.serverCodecConfigurer = serverCodecConfigurer;
    }
    @Bean
    @Order(Ordered.HIGHEST_PRECEDENCE)
    public ErrorWebExceptionHandler errorWebExceptionHandler(ErrorAttributes errorAttributes) {
        JSONExceptionHandler exceptionHandler = new jsonExceptionHandler(
                errorAttributes,
                this.resourceProperties,
                this.serverProperties.getError(),
                this.applicationContext);
        exceptionHandler.setViewResolvers(this.viewResolvers);
        exceptionHandler.setMessageWriters(this.serverCodecConfigurer.getWriters());
        exceptionHandler.setMessageReaders(this.serverCodecConfigurer.getReaders());
        return exceptionHandler;
    }
}

JsonExceptionHandler

package com.stu.getway.handler;
import org.springframework.boot.autoconfigure.web.ErrorProperties;
import org.springframework.boot.autoconfigure.web.ResourceProperties;
import org.springframework.boot.autoconfigure.web.reactive.error.DefaultErrorWebExceptionHandler;
import org.springframework.boot.web.reactive.error.ErrorAttributes;
import org.springframework.context.ApplicationContext;
import org.springframework.http.httpstatus;
import org.springframework.web.reactive.function.server.*;
import java.util.HashMap;
import java.util.Map;

public class JsonExceptionHandler extends DefaultErrorWebExceptionHandler {
    public JsonExceptionHandler(ErrorAttributes errorAttributes, ResourceProperties resourceProperties,
                                ErrorProperties errorProperties, ApplicationContext applicationContext) {
        super(errorAttributes, resourceProperties, errorProperties, applicationContext);
    }
    
    @Override
    protected Map<String, Object> getErrorAttributes(ServerRequest request, boolean includeStackTrace) {
        Map<String, Object> map = new HashMap<>();
        map.put("success", false);
        map.put("code", 20005);
        map.put("message", "网关失败");
        map.put("data", null);
        return map;
    }
    
    @Override
    protected RouterFunction<ServerResponse> getRoutingFunction(ErrorAttributes errorAttributes) {
        return RouterFunctions.route(RequestPredicates.all(), this::renderErrorResponse);
    }
    
    @Override
    protected int getHttpStatus(Map<String, Object> errorAttributes) {
        return 200;
    }
}

到此这篇关于getway网关的文章就介绍到这了,更多相关getway网关内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 浅析getway网关

本文链接: https://www.lsjlt.com/news/153915.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 浅析getway网关
    目录一、网关基本概念1、API网关介绍2、Spring Cloud Gateway3、Spring Cloud Gateway核心概念二、getway网关例子1、在infrastru...
    99+
    2022-11-13
  • Java基础之super关键字浅析
    目录一、定义二、应用2.1    应用范围2.2    用法2.2.1    在子类中调用父类的属性或方法2.2.2 &n...
    99+
    2022-11-13
  • 浅析关闭Golang程序的方法
    Golang是一种流行的编程语言,但是当你不需要继续使用它时,关闭它可能会有点棘手。以下是一些简单的方法,可以帮助你关闭Golang程序:Ctrl+C:在运行Golang程序时,你可以使用键盘上的“Ctrl+C”快捷键来关闭程序。这个方法在...
    99+
    2023-05-14
  • 浅析微信vue的关闭方法
    微信Vue是一种基于Vue.js构建的微信公众号开发框架,可以帮助开发者更快速、高效地开发微信公众号。但是,有时候我们需要关闭这个Vue框架,本文将详细介绍微信Vue的关闭方法。一、什么是微信Vue微信Vue是一个帮助开发者更好地开发微信公...
    99+
    2023-05-14
  • 浅析Java关键词synchronized的使用
    目录1 引入Synchronized2 Synchronized的使用2.1 对象锁2.2 类锁3 Synchronized原理分析3.1 虚拟机如何辨别和处理synchronize...
    99+
    2022-12-30
    Java关键词synchronized Java synchronized
  • 深入浅析Java中的 static关键字
    本篇文章为大家展示了深入浅析Java中的 static关键字,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、 static代表着什么      在...
    99+
    2023-05-31
    java 关键字 static
  • 关于mysql时间区间问题浅析
    目录一、between……and……二、&lt;和&gt;问题三、在java代码中拼接四、转变格式查询附:My...
    99+
    2022-11-13
  • 怎么浅析C++中的C++关键字
    怎么浅析C++中的C++关键字,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在C++语言中,然后就总结了许多C++关键字,如果不使用常引用、指针,则须用const_cast&l...
    99+
    2023-06-17
  • 深入浅析Java中的this、final关键字
    这篇文章给大家介绍深入浅析Java中的this、final关键字,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。this关键字this引用对象自身。它也可以在构造方法内部用于调用同一个类的其他构造方法。 隐藏的静态变量可...
    99+
    2023-05-31
    java this final
  • 浅谈一下关于Python对XML的解析
    目录什么是XML?python对XML的解析1.SAX (simple API for XML )2.DOM(Document Object Model)3.ElementTree(...
    99+
    2023-05-12
    Python XML Python XML解析
  • 关于MySQL的时间进位问题浅析
    MySQL 当中默认的时间类型(datetime 和 timestamp)的精度是秒,如果设置进去的时间值精度小于秒的话,就会被四舍五入,可能导致数据库中的值比原始值多了一秒。也就是说,本来属于今天的记录可...
    99+
    2022-10-18
  • 怎么深入浅析ASO关键词优化
    怎么深入浅析ASO关键词优化 ,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。SEO人会经常自己挖掘一些长尾词,一般常用的做法是关注本行业即时出现的热点新闻、轰动...
    99+
    2023-06-10
  • 浅析Android手机卫士关闭自动更新
    推荐阅读: 浅析Android手机卫士自定义控件的属性 保存数据的四种方式,网络,广播提供者,SharedPreferences,数据库 获取SharedPreferences...
    99+
    2022-06-06
    关闭自动更新 自动 自动更新 更新 关闭 Android
  • 和浅析ASP.NET MVC中关于URL Rewrite的实现
    这期内容当中小编将会给大家带来有关和浅析ASP.NET MVC中关于URL Rewrite的实现,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。现在我们就来看一个真实案例:在ASP.NET MVC中使用II...
    99+
    2023-06-17
  • 浅析对Java关键字final和static的理解
    一、final            根据程序上下文环境,Java关键字final有“这是无法改变的”或者“终态的”含义,它可以修...
    99+
    2023-05-31
    java static final
  • Gateway网关源码解析
    目录工作原理配置类分析路由模式源码分析解决前后端的跨域问题工作原理 客户端向 Spring Cloud Gateway 发出请求。 如果网关处理程序映射确定请求与路由匹配,则将其发...
    99+
    2022-11-13
  • php怎么屏蔽关键字?两种方法浅析
    PHP是一种广泛用于Web开发的服务器端脚本语言。在现代Web开发中,开发人员通常需要处理大量的用户数据。有时候,这些用户可能会提交一些恶意的文本,例如攻击代码、广告、垃圾邮件等等。为了保护我们的Web应用程序不受这些恶意文本的影响,我们需...
    99+
    2023-05-14
    php
  • 浅析Python中yield关键词的作用与用法
    前言 为了理解yield是什么,首先要明白生成器(generator)是什么,在讲生成器之前先说说迭代器(iterator),当创建一个列表(list)时,你可以逐个的读取每一项,这就叫做迭代(iterat...
    99+
    2022-06-04
    关键词 作用 Python
  • 关于Spring框架中异常处理情况浅析
    1.编写一个类,实现HandlerExceptionResolver接口 @Component public class ExceptionResolver implements...
    99+
    2022-11-12
  • 浅析PHP与Vue、React之间的关系,怎么选?
    随着前端技术的迅速发展,热门的前端框架也在不断涌现。其中,React和Vue是目前最受欢迎的前端框架之一。但是,当我们在使用PHP时,我们应该使用Vue还是React呢?在这篇文章中,我们将分析PHP与Vue、React之间的关系,并探讨哪...
    99+
    2023-05-14
    php Vue React
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作