从零到一搭建nacos微服务之gateway网关【全报文安全处理】(三)

网关的角色是作为一个 API 架构,用来保护、增强和控制对于 API 服务的访问
API 网关是一个处于应用程序或服务(提供 REST API 接口服务)之前的系统,用来管理授权、访问控制和流量限制等,这样 REST API 接口服务就被 API 网关保护起来,对所有的调用者透明。因此,隐藏在 API 网关后面的业务系统就可以专注于创建和管理服务,而不用去处理这些策略性的基础设施.。主要的功能大概下面这几点

  • 性能:API高可用,负载均衡,容错机制。
  • 安全:权限身份认证、脱敏,流量清洗,后端签名
  • 黑名单。
  • 日志:日志记录一旦涉及分布式,全链路跟踪必不可少。
  • 缓存:数据缓存。监控:记录请求响应数据,api耗时分析,性能监控。
  • 限流:流量控制,错峰流控,可以定义多种限流规则。
  • 灰度:线上灰度部署,可以减小风险。
  • 路由:动态路由规则。

这篇文章主要的内容是spring cloud gateway 对请求参数解密,返回参数加密处理以及密钥下发处理

一,搭建基本gateway项目

1.1 maven

         <!--gateway -->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-gateway</artifactId>
		</dependency>

1.2本地appcation.yml配置

server:
  port: 8087
spring:
  profiles:
    active: dev
  application:
    name: nacos-gateway
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

1.3本地bootstrap.properties配置

因为项目是整合的nacos,所以这里网关的配置也从nacos取

#项目名
spring.application.name=nacos-gateway
#配置中心地址
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#配置文件尾缀
spring.cloud.nacos.config.file-extension=yml
#配置组
spring.cloud.nacos.config.group=DEV
#命名空间
#spring.cloud.nacos.config.namespace: 7a36049b-ce40-4a3a-97d0-c86858fdcc0f
spring.cloud.nacos.config.refresh-enabled=true



spring.cloud.nacos.config.extension-configs[0].data-id=nacos-gateway-commons.yml
spring.cloud.nacos.config.extension-configs[0].group=DEV
spring.cloud.nacos.config.extension-configs[0].refresh=true

spring.cloud.nacos.config.extension-configs[1].data-id=nacos-gateway-route.yml
spring.cloud.nacos.config.extension-configs[1].group=DEV
spring.cloud.nacos.config.extension-configs[1].refresh=true

这里引入nacos-gateway-route.yml配置如下

nacos-gateway-route.yml

这个是网关路由项目的配置

spring:
  cloud:
    gateway:
      discovery:
        locator:
          enabled: false  
          #lower-case-service-id: true 
      routes:  #路由数组
        - id: nacos-user  #路由
          uri:  lb://nacos-user #lb 指的是负载均衡 后面是nacos的服务名
          order: 1 #路由优先级  数字越小越大
          predicates:  #断言数组(条件判断,返回值boolean ,转发请求满足条件的)
            - Path=/nacos-user/**
          filters: #过滤器 数组 (在请求传递过程中,对请求做修改)
            - StripPrefix=1 #在请求转发之前去掉 gateway的一层路径
        - id: nacos-order  #路由
          uri:  lb://nacos-order #lb 指的是负载均衡 后面是nacos的服务名
          order: 1 #路由优先级  数字越小越大
          predicates:  #断言数组(条件判断,返回值boolean ,转发请求满足条件的)
            - Path=/nacos-order/**
          filters: #过滤器 数组 (在请求传递过程中,对请求做修改)
            - StripPrefix=1 #在请求转发之前去掉 gateway的一层路径
<
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答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搭建微服务的简易步骤。和其他微服务框架相比,这种搭配是比较新的,但在性能方面有很好的优势。在实际应用中,还需要根据具体情况进行优化和改进,进一步提升系统的稳定性和性能表现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值