微服务实战系列(七)-网关springcloud gateway

1. 场景描述

springcloud刚推出的时候用的是netflix全家桶,路由用的zuul,但是据说zull1.0在大数据量访问的时候存在较大性能问题,2.0就没集成到springcloud中了,springcloud推出了自己的路由-springcloud gateway,亲儿子,目前官网主推。

netfelix的zull路由:

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

2. 解决方案

2.1 新建springboot项目

在springcloud项目中,新建的项目全部是基于springboot的。

2.1.1 new->project
image

next->next 更改下项目名称。

2.1.2 选择组件

(1)注册中心客户端

image

(2) 选择springcloud gateway

image

next->next, 完成。

2.2 类目录图

开始介绍springcloud-gateway,为了区分上一篇的关于zull的介绍,项目名称设置为springgate。

image

2.3 重点还是三个文件

2.3.1 pom.xml


    4.0.0
    
        org.springframework.boot
        spring-boot-starter-parent
        2.1.5.RELEASE
         
    
    com.yutong
    springgateway
    0.0.1-SNAPSHOT
    springgateway
    Demo project for Spring Boot

    
        1.8
        Greenwich.SR1
    

    
        
            org.springframework.cloud
            spring-cloud-starter-gateway
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    



说明,重点就两个starter:

(1)gateway,不同于zull,这个是直接位于spring-cloud下面,是springcloud的嫡系部队。

(2)注册中心客户端,不多说了

2.3.2 启动类application
package com.yutong.springgateway;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.gateway.route.RouteLocator;
import org.springframework.cloud.gateway.route.builder.RouteLocatorBuilder;
import org.springframework.context.annotation.Bean;

@SpringBootApplication
public class SpringgatewayApplication {

    @Value("${test.uri}")
    private String uri;


    @Bean
    public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
        return builder.routes()
                //basic proxy
                .route(r -> r.path("/**")
                        .uri(uri)
                ).build();
    }



    public static void main(String[] args) {
        SpringApplication.run(SpringgatewayApplication.class, args);
    }

}

说明:

(1)不同于路由zull,需要zull的标签,这里只需要springboot的启动标签@SpringBootApplication就可以了。

(2)增加@Bean标签,RouteLocator 是路由规则,这个稍微复杂点,示例中只做了简单配置,路由规则用于过滤控制路由等,可根据具体需求,参考路由规则API进行设置。

2.3.3 配置类application.yml
test:
  uri: lb://client

spring:
  application:
    name: springgateway
  cloud:
    gateway:
      discovery:
        locator:
          lower-case-service-id: true

eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka

server:
  port: 9000

说明:

(1)第一行的uri在启动类application中用到,指访问的客户端服务,client为注册中心客户端服务名称。

(2)defaultZone为注册中心地址。

(3) 为了区分介绍zull的项目,name设置为:springgateway

2.3.4 效果图

(1)注册中心

image

(2)路由springcloud gateway访问

image

说明:

路由访问的时候不需要指定客户端名称client,因为在gateway启动类中已经指定过了。


更多知识请关注公众号:「软件老王」,IT技术与相关干货分享,回复关键字获取对应干货!

你可能感兴趣的:(微服务实战系列(七)-网关springcloud gateway)