美文网首页
Spring Cloud gateway 网关服务简单应用

Spring Cloud gateway 网关服务简单应用

作者: __元昊__ | 来源:发表于2020-01-15 14:15 被阅读0次

    上一代产品 zuul网关服务,今天聊聊spring cloud gateway 作为spring cloud的亲儿子网关服务。很多的想法都是参照zuul,为了考虑zuul 迁移到gateway 提供了一个便利的条件。

    gateway 他的核心功能也是和zuul 类似。但是他的实现方式与zuul 却有些不一样,他的核心是基于 Spring Boot 2.x, Spring WebFlux和Project Reactor 构建的。

    • Spring WebFlux 响应式Web框架。

    • Spring WebFlux是基于响应式流的,因此可以用来建立异步的、非阻塞的、事件驱动的服务。它采用Reactor作为首选的响应式流的实现库,不过也提供了对RxJava的支持。
      由于响应式编程的特性,Spring WebFlux和Reactor底层需要支持异步的运行环境,比如Netty和Undertow;也可以运行在支持异步I/O的

    • Servlet 3.1的容器之上,比如Tomcat(8.0.23及以上)和Jetty(9.0.4及以上)。

    • spring-webflux上层支持两种开发模式:

    • 类似于Spring WebMVC的基于注解(@Controller、@RequestMapping)的开发模式;

    • Java 8 lambda 风格的函数式开发模式。

    • Spring WebFlux也支持响应式的Websocket服务端开发。

    所以spring cloud gateway 不是基于阻塞的web 开发。他与传统的Servlet是存在冲突的。在创建功能的时候要排除掉传统的Servlet jar包引用

    修改之前工程的pom 文件总pom 里面我们有一个 spring-boot-starter-web 工程引用,删除掉。在服务里面单独依赖。上面已经讲述过,传统Servlet的jar包冲突问题。

    pom.xml

    <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-actuator</artifactId>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-openfeign</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-gateway</artifactId>
            </dependency>
    
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
            </dependency>
        </dependencies>
    

    创建 bootstrap.yml

    server:
      port: 56010 #启动端口 命令行注入
    
    spring:
      application:
        name: gateway
      main:
        allow-bean-definition-overriding: true # Spring Boot 2.1 需要设定
      cloud:
        nacos:
          discovery:
            server-addr: 127.0.0.1:8848
            namespace: 86d0bae8-65e4-4ed3-9323-964cc8e6e3e3
          config:
            server-addr: 127.0.0.1:8848 # 配置中心地址
            file-extension: yaml
            namespace: 86d0bae8-65e4-4ed3-9323-964cc8e6e3e3 # 开发环境
        gateway:
          discovery:
            locator:
              enabled: true #设置与服务发现组件结合,可以采用服务名策略
          routes:
            - id: application1
              uri: lb://application1
              predicates:
                - Path=/client/**   # 路径匹配,以 api 开头,直接配置是不生效的,看 filters 配置
              filters:
                - StripPrefix=1  # 前缀过滤,默认配置下,我们的请求路径是 http://localhost:56010/application1/** 这时会路由到指定的服务
                                  # 此处配置去掉 1 个路径前缀,再配置上面的 Path=/api/**,就能按照 http://localhost:56010/api/** 的方式访问了
    

    创建main 启动类

    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
    import org.springframework.cloud.openfeign.EnableFeignClients;
    
    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableFeignClients
    public class GatewayBootstrap {
        public static void main(String[] args) {
            SpringApplication.run(GatewayBootstrap.class,args);
        }
    }
    

    启动服务 访问 http://localhost:56010/client/service_feign

    QQ截图20200115141425.png

    服务已经整合完毕。路由功能转发已经实现。配置文件的一些字段的说明也在注释上说明。

    相关文章

      网友评论

          本文标题:Spring Cloud gateway 网关服务简单应用

          本文链接:https://www.haomeiwen.com/subject/xnjtzctx.html