Nacos与Gateway微服务网关

结合E:\Codes\Idea_java_works\apesource\springboot\微服务\springboot_gateway

简介

在此之前,我们调用服务需要记忆不同的端口号,非常麻烦,使用gateway网关就可以直接访问网关的端口号,

让网关在nacos中寻找服务,并且转发到相对应服务的端口号。

Gateway服务⽹关 Spring Cloud Gateway 是 Spring Cloud 的⼀个全新项⽬,该项⽬是基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等响应式编程和事件流技术开发的⽹关,它旨在为微服务架构提供 ⼀种简单有效的统⼀的 API 路由管理⽅式。

操作流程

  1. 创建gateway服务,引⼊依赖 创建服务: 创建⼀个 api-gateway 的模块,导⼊相关依赖
<!--⽹关-->
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-gateway</artifactId>
  <version>2.1.3.RELEASE</version>
</dependency>
<!--nacos服务发现依赖(gateway⾼级使⽤需要)-->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  <version>2.1.3.RELEASE</version>
</dependency>
  1. 编写api-gateway的配置文件
#########################高级版本##################################
#启动类添加注解@EnabLeDiscoveryClient,项目添加坐标
server:
  port: 7000
spring:
  application:
    name: api-gateway
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
    gateway:
      discovery:
        locator:
          enabled: true                               # 让gateway可以发现nacos中的微服务
      routes:                                         # 路由数组[路由就是指定当请求满⾜什么条件的时候转到哪个微服务]
        - id: product_route
          uri: lb://server-product                    # 指的是从nacos中按照名称获取微服务,并遵循负载均衡策略
          order: 1                                    # 路由优先级 数字越低优先级越高
          predicates:                                 # 断言
            - Path=/product/**                        # 当请求路径满⾜Path指定的规则时,才进⾏路由换发
          filters:
            - StripPrefix=1                           # 拼接好url之后去掉1层路径也就是product
            - AddRequestHeader=msg,abc
        - id: order_route
          uri: lb://server-order                      # 指的是从nacos中按照名称获取微服务,并遵循负载均衡策略
          order: 1                                    # 路由优先级 数字越低优先级越高
          predicates:                                 # 断言
            - Path=/order/**                          # 当请求路径满⾜Path指定的规则时,才进⾏路由换发
          filters:
            - StripPrefix=1                           # 拼接好url之后去掉1层路径也就是product
            - AddRequestHeader=msg,abc
  1. 发送请求测试
  • 例如之前发的是localhost:8080/product/1
  • 现在就是 localhost:7000/product/product/1

断言工厂

例如Path=/user/**是按照路径匹配,这个规则是由org.springframework.cloud.gateway.handler.predicate.PathRoutePredicateFactory类来处理 的,像这样的断⾔⼯⼚在SpringCloudGateway还有⼗⼏个:

名称

说明

示例

After

是某个时间点后的请求

-After=2037-01-20T17:42:47.789-07:0o[America/Denver]

Before

是某个时间点之前的请求

- Before=2031-04-13T15:14:47.433+08:00[Asia/Shanghai]

Between

是某两个时间点之前的请求

-Between=2037-01-20T17:42:47.789-07:00[America/Denver], 2037-01-21T17:42:47.789-07:00[America/Denver]

Cookie

请求必须包含某些cookie

-Cookie=chocolate, ch.p

Header

请求必须包含某些header

-Header=X-Request-Id, \d+

Host

请求必须是访问某个host

(域名)

-Host=.somehost.org,.anotherhost.org

Method

请求方式必须是指定方式

-Method=GET,POST

Path

请求路径必须符合指定规则

-Path=/red/{segment},/blue/**

Query

请求参数必须包含指定参

-Query=name,Jack或者-Query=name

RemoteAddr

请求者的ip必须是指定范围

-RemoteAddr=192.168.1.1/25

Weight

权重处理

过滤器工厂

GatewayFilter是⽹关中提供的⼀种过滤器,可以对进⼊⽹关的请求和微服务返回的响应做处理:

名称

说明

AddRequestHeader

给当前请求添加一个请求头

RemoveRequestHeader

移除请求中的一个请求头

AddResponseHeader

给响应结果中添加一个响应头

RemoveResponseHeader

从响应结果中移除有一个响应头

RequestRateLimiter

限制请求的流量

路由过滤器(当前路由的过滤器)
routes:                                         # 路由数组[路由就是指定当请求满⾜什么条件的时候转到哪个微服务]
  - id: product_route
    uri: lb://server-product                    # 指的是从nacos中按照名称获取微服务,并遵循负载均衡策略
    order: 1                                    # 路由优先级 数字越低优先级越高
    predicates:                                 # 断言
      - Path=/product/**                        # 当请求路径满⾜Path指定的规则时,才进⾏路由换发
    filters:
      - StripPrefix=1                           # 拼接好url之后去掉1层路径也就是product
@GetMapping("/{id}")
public Product selectById(@PathVariable int id) {
    Product product = service.getById(id);
    log.info(product.toString());
    return product;
}
默认过滤器(范围是所有路由,但是只能使用默认提供的过滤规则)

举例AddRequestHeader

配置文件

routes:                                         # 路由数组[路由就是指定当请求满⾜什么条件的时候转到哪个微服务]
  - id: product_route
    uri: lb://server-product                    # 指的是从nacos中按照名称获取微服务,并遵循负载均衡策略
    order: 1                                    # 路由优先级 数字越低优先级越高
    predicates:                                 # 断言
      - Path=/product/**                        # 当请求路径满⾜Path指定的规则时,才进⾏路由换发
    filters:
      - StripPrefix=1                           # 拼接好url之后去掉1层路径也就是product
default-filters: 																# 默认过滤器 范围全局
  - AddRequestHeader=msg,abc 

Handler

@GetMapping("/{id}")
public Product selectById(@PathVariable int id,@RequestHeader(value = "msg") String msg) {
    Product product = service.getById(id);
    System.out.println(msg);
    System.out.println(msg);
    System.out.println(msg);
    System.out.println(msg);
    System.out.println(msg);
    log.info(product.toString());
    return product;
}
全局过滤器-登录校验(范围是所有路由,可以自定义过滤规则,拦截未登录用户)
  • 登录状态判断
  • 权限校验
  • 请求限流等

需求:定义全局过滤器,拦截请求,判断请求的参数是否满⾜下⾯条件:

● 参数中是否有authorization, authorization参数值是否为admin

●如果同时满⾜则放⾏,否则拦截 实现:在gateway中定义⼀个过滤器:

package com.ape.apigateway.filter;

import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.annotation.Order;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

//导入IOC就可以生效
@Component
@Order(-1) // 用来控制优先级 数字越小优先级越高
public class AuthorizeFilter implements GlobalFilter {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String token = exchange.getRequest().getHeaders().get("authorization").get(0);
        if (token.equals("admin")){
            //            放行
            return chain.filter(exchange);
        }
        //        拦截 禁止访问
        exchange.getResponse().setStatusCode(HttpStatus.UNAUTHORIZED);
        return exchange.getResponse().setComplete();
    }
}
过滤器执行顺序

默认===》路由===》全局

跨域解决方案

跨域:域名不⼀致就是跨域,主要包括:

  • 域名不同: www.taobao.com 和 www.taobao.org 和 www.jd.com 和 miaosha.jd.com
  • 域名相同,端⼝不同:localhost:8080和localhost8081

跨域问题:浏览器禁⽌请求的发起者与服务端发⽣跨域ajax请求,请求被浏览器拦截的问题

CORS是跨源资源分享(Cross-Origin Resource Sharing)的缩写。它是W3C标准,是跨源AJAX请求 的根本解决⽅法。相⽐JSONP只能发GET请求,CORS允许任何类型的请求。 在gateway服务的application.yml⽂件中,添加下⾯的配置:

spring:
  cloud:
    gateway:
      globalcors: # 全局的跨域处理
        add-to-simple-url-handler-mapping: true # 解决options请求被拦截问题
        corsConfigurations:
          '[/**]':
            allowedOrigins: # 允许哪些⽹站的跨域请求
              - "http://localhost:8090"
            allowedMethods: # 允许的跨域ajax的请求⽅式
              - "GET"
              - "POST"
              - "DELETE"
              - "PUT"
              - "OPTIONS"
            allowedHeaders: "*" # 允许在请求中携带的头信息
            allowCredentials: true # 是否允许携带cookie
            maxAge: 360000 # 这次跨域检测的有效期

  • 14
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: GatewayNacos是搭建微服务架构的两个重要组件。 Gateway作为微服务架构中的API网关,可以将所有的外部请求导向到正确的微服务实例。Gateway的配置需要定义路由规则,指定请求的路径和目标服务的地址等信息。 Nacos微服务注册中心和配置中心,可以为微服务实例提供服务注册和发现的功能。通过Nacos微服务可以注册自己的实例,并查找其他微服务实例的地址和端口号。 要搭建微服务架构,首先需要在Nacos中注册所有的微服务实例。然后在Gateway中定义路由规则,指定请求的路径和目标服务的地址。当客户端请求到达Gateway时,Gateway会根据路由规则将请求转发到相应的微服务实例。 需要注意的是,在搭建微服务架构时,还需要考虑负载均衡、熔断、限流等方面的问题,以确保微服务的稳定性和可靠性。 ### 回答2: 在当今云原生时代,微服务已成为许多企业和开发者的首选架构,而gatewaynacos则是常用的微服务组件之一。 Gateway是Spring Cloud的一个子项目,是一个API网关,它的主要作用是为微服务提供统一的入口和请求路由控制,同时还可以进行鉴权、限流、降级等功能。和普通的web服务相比,Gateway具有更高的性能和可扩展性。 而Nacos则是阿里巴巴开源的一款基于服务治理的中间件,主要用于服务发现、配置管理以及流量管理。Nacos可以帮助我们实现服务注册、配置管理、服务发现等功能,比较适合用来构建微服务的基础设施。 下面我们来看一下如何使用GatewayNacos来搭建微服务。 1. 安装Nacos服务器并启动 首先需要下载Nacos服务器并启动。可以到官网下载最新版Nacos服务器,解压后进入bin目录,通过启动脚本启动Nacos服务器: ```bash sh startup.sh -m standalone ``` 2. 引入依赖和配置Gateway 接下来需要引入Gateway的依赖和进行相关配置。在pom.xml文件中添加Gateway的依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> <version>2.2.5.RELEASE</version> </dependency> ``` 在application.yml文件中添加Gateway的相关配置信息: ```yaml spring: cloud: gateway: routes: - id: service-example uri: lb://service-example predicates: - Path=/example/** ``` 其中,id指定了路由的名称,uri指定了微服务的地址,predicates则指定了请求的匹配规则。 3. 注册微服务Nacos 接下来需要将微服务注册到Nacos服务器中,以便Gateway可以进行服务发现和路由控制。在微服务的配置文件中添加Nacos相关的配置信息: ```yaml spring: application: name: service-example cloud: nacos: discovery: server-addr: 127.0.0.1:8848 config: server-addr: 127.0.0.1:8848 namespace: dev ``` 4. 启动微服务Gateway 最后一步就是启动微服务Gateway。可以通过Spring Boot的插件启动微服务: ```bash mvn spring-boot:run ``` 启动Gateway的方式也类似: ```bash mvn spring-boot:run -Dspring-boot.run.profiles=gateway ``` 启动完成后,就可以通过Gateway访问微服务了。例如,可以通过http://localhost:8080/example/xxx访问到微服务中的/example/xxx接口。 总的来说,GatewayNacos搭建微服务是一个比较简单的过程,它们的出现大大简化了微服务的部署和治理,减轻了开发者的负担,值得我们在实际项目中使用和研究。 ### 回答3: GatewayNacos是目前常用的两个微服务框架。Gateway是Spring Cloud Gateway的简称,是一个基于Spring Boot的反向代理框架,它可以进行路由控制、请求转发和筛选等一系列操作。而Nacos是一个基于服务中心的微服务平台,它可以进行服务注册、配置管理和健康检查等操作。 将这两个框架搭配起来,可以方便实现微服务的注册与发现、服务网关的动态路由等操作。下面是具体的搭建步骤: 1.安装Nacos,可从官网下载并安装。Nacos包含一个控制台和一个服务端,可以使用默认配置运行或者进行自定义。 2.在控制台中注册微服务。在控制台中创建一个命名空间,之后再创建微服务。服务创建完成后,可以在控制台上查看服务的实例列表信息。 3.在网关服务中进行配置。在网关的application.properties或者application.yml文件中,可以进行Nacos配置扫描的位置和启用eureka。如: eureka: client: service-url: defaultZone: http://localhost:8181/eureka/ spring: cloud: gateway: discovery: locator: enabled: true lowerCaseServiceId: true predicates: - name: DiscoveryClient 4.启动网关服务。启动网关应用程序后,可以使用浏览器或者Postman等工具来验证路由规则是否生效。 以上是GatewayNacos搭建微服务的简易步骤。和其他微服务框架相比,这种搭配是比较新的,但在性能方面有很好的优势。在实际应用中,还需要根据具体情况进行优化和改进,进一步提升系统的稳定性和性能表现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值