网关Gateway作用介绍和快速入门

目前架构问题分析

这里有很多微服务,每个微服务都需要晚上访问数据库去完成各自的业务,并且需要在nacos进行注册和管理,每一个微服务之间需要相互调用的时候,可以用Feign进行调用,当外部需要访问的时候,就直接发请求到微服务,就会产生问题,任何一个机器都可以访问到微服务,就会不安全

解决方案------网关

  • 身份认证和权限校验
  • 服务路由、负载均衡
  • 请求限流

网关的技术实现

  • gateway
  • zuul

Zuul是 基于Servlet的实现,属于阻塞式编程 。而SpringCloudGateway 则是基于Spring5中提供的WebFlux,属于响应式编程的实现,具备更好的性能。

总结

  • 网关的作用:
    • 对用户请求做身份认证、权限校验
    • 将用户请求路由到微服务,并实现负载均衡
    • 对用户请求做限流

搭建网关服务

引入依赖

创建新的module,引入SpringCloudGateway 的依赖和nacos的服务发现依赖

复制代码
        <!--网关依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <!--nacos服务发现依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

路由配置

编写路由配置及nacos地址

复制代码
spring:
  application:
    name: gateway # 服务名称
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos地址
    gateway:
      routes: # 网关路由配置
        - id: user-service # 路由id,自定义,只要唯一即可
          # uri: http://127.0.0.1:8081 # 路由的目标地址 http就是固定地址
          uri: lb://userservice # 路由的目标地址 lb就是负载均衡,后面跟服务名称
          predicates: # 路由断言,也就是判断请求是否符合路由规则的条件
            - Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求
        - id: order-service
          uri: lb://orderservice
          predicates:
            - Path=/order/**

测试

浏览器访问:http://localhost:10010/user/1

流程图

总结

  • 网关搭建步骤:
    1. 创建项目,引入nacos服务发现和gateway依赖
    2. 配置application.yml,包括服务基本信息、nacos地址、路由
  • 路由配置包括:
    1. 路由id:路由的唯一标示
    2. 路由目标(uri):路由的目标地址,http代表固定地址,lb代表根据服务名负载均衡
    3. 路由断言(predicates):判断路由的规则,
    4. 路由过滤器(filters):对请求或响应做处理
相关推荐
无情白2 分钟前
k8s运维面试总结(持续更新)
运维·面试·kubernetes
H1346948901 小时前
企业服务器备份软件,企业服务器备份的方法有哪些?
运维·服务器·负载均衡
塔能物联运维3 小时前
塔能科技:精准节能,擎动工厂可持续发展巨轮
大数据·运维
小王努力学编程3 小时前
【Linux系统编程】进程概念,进程状态
linux·运维·服务器·c++
liuliu03234 小时前
戴尔笔记本 ubuntu 22.04 开机后进入initramfs界面
linux·运维·ubuntu
Yan-英杰5 小时前
DeepSeek-R1模型现已登录亚马逊云科技
java·大数据·人工智能·科技·机器学习·云计算·deepseek
DADIAN_GONG6 小时前
incomplete command on Huawei switch
linux·运维·华为
水星灭绝6 小时前
orangepi zero烧录及SSH联网
运维·ssh
緣起緣落6 小时前
Linux(CentOS 7) 部署 redis 集群
linux·运维·服务器·redis·centos·集成学习
无名之逆7 小时前
[特殊字符] Hyperlane 框架:高性能、灵活、易用的 Rust 微服务解决方案
运维·服务器·开发语言·数据库·后端·微服务·rust