Spring Cloud Gateway示例 | DevGlan

栏目: Java · 发布时间: 4年前

内容简介:这是讨论了Spring cloud网关并使用它创建了一个演示应用程序。源代码可以从在这个实现中,我们将有2个不同的基于Spring Boot的微服务作为第一服务和第二服务。这些服务将自己注册到发现服务器。Spring云网关将使用Netflix客户端API发现服务并将请求路由到负载均衡的下游服务。首先生成一个Spring Boot项目,选定的依赖项是Gateway,Hystrix和Actuator。我们还将在我们的pom中添加spring-cloud-starter-netflix-eureka-client

这是讨论了Spring cloud网关并使用它创建了一个演示应用程序。源代码可以从 github 下载。

在这个实现中,我们将有2个不同的基于Spring Boot的微服务作为第一服务和第二服务。这些服务将自己注册到发现服务器。Spring云网关将使用Netflix客户端API发现服务并将请求路由到负载均衡的下游服务。

首先生成一个Spring Boot项目,选定的依赖项是Gateway,Hystrix和Actuator。我们还将在我们的pom中添加spring-cloud-starter-netflix-eureka-client依赖。

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

Spring云路由配置

Route是网关的基本构建块。它由ID,目标URI,谓词集合和过滤器集合定义。如果聚合谓词为真,则匹配路由。

Spring Cloud Gateway提供了许多内置路由谓词工厂,如路径,主机,日期/时间,方法,标题等。我们可以使用这些内置路由与and()或or()结合来定义我们的路由。一旦请求到达网关,网关所做的第一件事就是根据定义的谓词将请求与每个可用路由进行匹配,并将请求路由到匹配的路由。

以下是我们的路由配置。我们为2个微服务定义了2条不同的路由 - 第一服务和第二服务。

@Configuration
<b>public</b> <b>class</b> BeanConfig {

    @Bean
    <b>public</b> RouteLocator gatewayRoutes(RouteLocatorBuilder builder) {
        <b>return</b> builder.routes()
                .route(r -> r.path(<font>"/api/v1/first/**"</font><font>)
                        .filters(f -> f.rewritePath(</font><font>"/api/v1/first/(?.*)"</font><font>, </font><font>"/${remains}"</font><font>)
                                .addRequestHeader(</font><font>"X-first-Header"</font><font>, </font><font>"first-service-header"</font><font>)
                                .hystrix(c -> c.setName(</font><font>"hystrix"</font><font>)
                                        .setFallbackUri(</font><font>"forward:/fallback/first"</font><font>)))
                        .uri(</font><font>"lb://FIRST-SERVICE/"</font><font>)
                        .id(</font><font>"first-service"</font><font>))

                .route(r -> r.path(</font><font>"/api/v1/second/**"</font><font>)
                        .filters(f -> f.rewritePath(</font><font>"/api/v1/second/(?.*)"</font><font>, </font><font>"/${remains}"</font><font>)
                                .hystrix(c -> c.setName(</font><font>"hystrix"</font><font>)
                                        .setFallbackUri(</font><font>"forward:/fallback/second"</font><font>)))
                        .uri(</font><font>"lb://SECOND-SERVICE/"</font><font>)
                        .id(</font><font>"second-service"</font><font>))
                .build();
    }

}
</font>

在上面的配置中,第一个路由与一个路径匹配,该路径的谓词定义为匹配URL /api/v1/queue/**所有请求,然后这些多个过滤器(如rewritePath addRequestHeader)将应用激活,这些都是由开箱即用的网关提供的内置过滤器。

rewritePath过滤器采用路径regexp参数和替换参数;AddRequestHeader GatewayFilter Factory接受名称和值参数,并在请求中添加已配置的标头参数;Hystrix GatewayFilter Factory需要单个名称参数,该参数是HystrixCommand的名称。请求将被转发到与fallbackUri参数匹配的控制器。

下面是一个等效的application.yaml配置:

spring
    cloud:
        gateway:
          routes:
          - id: first-service
            uri: lb:<font><i>//FIRST-SERVICE</i></font><font>
            predicates:
            - Path=/api/v1/first</font><font><i>/**
            filters:
            - RewritePath=/api/v1/first/(?.*), /$\{remains}
            - AddRequestHeader=X-first-Header, first-service-header
            - name: Hystrix
                args:
                  name: hystrix
                  fallbackUri: forward:/fallback/first
</i></font>

Spring Cloud Gateway应用程序配置

下面是我们的application.yaml文件。

hystrix.command.fallbackcmd.execution.isolation.thread.timeoutInMilliseconds:2000 
spring:
  application:
    name:api-gateway 

server:
  port:8088 

eureka:
  client:
    serviceUrl:
      defaultZone:http :// localhost :8761 / eureka 
    register-with- eureka:false 
  instance:
    preferIpAddress:true 

management:
  endpoints:
    web:
      exposure:
        include:hystrix.stream

Hystrix fallback 命令

下面是我们的控制器实现,其端点将在我们的微服务失败时被调用。

@RestController 
@RequestMapping(“/ fallback”)
public class HystrixController { 

    @GetMapping(“/ first”)
    public String firstServiceFallback(){ 
        return“这是第一个服务的后备。”; 
    } 

    @GetMapping(“/ second”)
    public String secondServiceFallback(){ 
        return“Second Server overloaded!请在一段时间后再试。”; 
    } 
}

以上所述就是小编给大家介绍的《Spring Cloud Gateway示例 | DevGlan》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

信息乌托邦

信息乌托邦

桑斯坦 / 毕竞悦 / 法律出版社 / 2008-10-1 / 28.50元

我们被无限的媒体网从四面包围,如何能够确保最准确的信息脱颖而出、并且引起注意?在本书中,凯斯•R. 桑斯坦对于积蓄信息和运用知识改善我们生活的人类潜能,展示了深刻的乐观理解。 在一个信息超负荷的时代里,很容易退回到我们自己的偏见。人群很快就会变为暴徒。伊拉克战争的合法理由、安然破产、哥伦比亚号航天载人飞机的爆炸——所有这些都源自埋于“信息茧房”的领导和组织做出的决定,以他们的先入之见躲避意见......一起来看看 《信息乌托邦》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具