Spring Cloud Gateway示例 | DevGlan

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

内容简介:这是讨论了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》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

基于模型的设计

基于模型的设计

2011-8 / 69.00元

《基于模型的设计:MSP430/F28027/F28335DSP篇》的最大特色就是软硬件结合,在使用最新版本Simulink的基础上,结合多型号板卡实现设计开发。书中不仅详细剖析了MSP430/F28027/F28335板卡功能,而且使用Simulink演示了从建模到模型验证、从定点设计到处理器在环、从代码生成到硬件联调等诸多方面,内容充实,确实是一本学习基于模型设计进行DSP开发的较为理想的工程......一起来看看 《基于模型的设计》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具