微服务5——服务的保护(API 网关(Spring Cloud Gateway)) sca-gateway

mst

面试:用网关吗?
说说网关的执行流程———好几个面试都问到了
网关配置过什么啊——谓词


网关:
什么是网关?
服务访问(流量)的一个入口,类似生活中的“海关“  外界不能随意访问,讲服务保护起来;并对这些服务进行统一的跨域配置 去
在网关设置统一跨域,这样就不用在控制层写@crossoigin注解了
为什么使用网关?作用(服务安全,统一服务入口管理,负载均衡,限流,鉴权)
为什么要使用api网关?(服务保护,统一url访问,统一身份认证,统一跨域设计,。。。)
Spring Cloud Gateway 应用的初始构建过程(添加依赖,配置)
Gateway 服务的启动底层是通过谁去实现的?(Netty网络编程框架-ServerSocket)
Gateway 服务做请求转发时一定要在注册中心进行注册吗?(不一定,可以直接通过远端url进行服务访问)
说说SpringCloud gateway处理请求的基本流程?(官方,断点)

负载均衡:
网关层面是如何实现负载均衡的?(通过服务名去查找具体的服务实例)
网关层面是如何通过服务名查找服务实例的?(Ribbon)
你了解Ribbon中的哪些负载均衡算法?(轮询,权重,hash,……可通过IRule接口进行查看分析)
网关进行请求转发的流程是怎样,有哪些关键对象?(XxxHandlerMapping,Handler,。。。)
网关层面服务的映射方式怎样的?(谓词-path,…,服务名/服务实例)
网关层如何记录服务的映射?(通过map,并要考虑读写锁的应用
网关项目中的负载均衡是如何实现?(底层基于Ribbon实现,可以在RibbonLoadBalancerClient中加断点分析)

断言/谓词(Predicate):
何为谓词?(网关中封装了判断逻辑的一个对象)
谓词逻辑的设计是怎样的?(谓词判断逻辑返回值为true则进行请求转发)
你了解哪些谓词逻辑?(path,请求参数,请求方式,请求头,….)
我们可以自己定义谓词工厂对象吗?(可以的)
网关中的谓词对象类型?(GatewayPredicate)
网关中的谓词对象是如何创建的?(谓词工厂)
你在网关中配置过哪些常用谓词?(Path,Method,Before,Query,Header,…)

过滤器(Filter):
网关中的过滤器是如何分类的?(GlobalFilter,GatewayFilter:需要手动配置)
我们是否可以自定义谓词,过滤器对象?(可以,参考官方默认的定义)
网关层面如何基于sentinel实现限流?(有关sentinel的两个依赖,配置,JVM参数)
网关层面的限流类型有哪些?(路由id,API分组)
我们是否可以对限流结果进行自定义处理?(可以)
网关过滤器的作用是什么?(对请求和响应数据做一个预处理)
网关过滤器的类型有哪些?(局部过滤器,全局过滤器)
如何理解局部过滤器?(针对具体链路的应用的过滤器,需要进行配置)
你了解哪些局部过滤器?
如何理解全局过滤器?(作用于所有请求链路)
如何自己定义全局过滤器?(直接或间接实现GlobalFilter接口)
假如现在让你进行平台的网关自研设计,你可以吗?(可以)


限流:
网关层面结合sentinel实现限流,其限流的类型有几种?(两种-route id,api)
网关层面可以自定义限流后的异常处理结果吗?(可以)
你知道Sentinel底层限流的算法有哪些?(滑动窗口,令牌桶,漏斗,。。。)

网关描述

通过网关作为服务访问入口,对系统中的服务进行访问,例如通过网关服务去访问sca-provider服务.

一、入门——开启Nacos服务和sca-provider服务 是前提

第一步:创建sca-gateway模块(假如已有则无须创建),在pom.xml文件中添加网关依赖,例如:

<dependencies>
        <!--添加api网管依赖,此以来自带一个web服务
        有了此依赖后,项目中不需要添加spring-boot-starter-web依赖了,加了会
        报错-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <!--我们自己写一些配置时最好加上这个注解-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
    </dependencies>

第二步:创建application.yml(假如已有则无须创建),添加相关配置,代码如下:

server:
  port: 9000

spring:
  application:
    name: sca-gateway   #服务名称
  cloud:
    gateway:
      routes: #配置网关路由规则——路由元素,此元素下可以定义多个路由
        - id: route01  #路由id,自己指定一个唯一值即可——每个路由都会有一个唯一标识
          uri: http://localhost:8081/ #网关帮我们转发的url——网关要基于路由转发的路径
          predicates: ###断言(谓词):匹配请求规则——这里定义请求转发规则
            - Path=/nacos/provider/echo/**  #请求路径定义,此路径对应uri中的资源
          filters: ##网关过滤器,用于对 断言(谓词) 中的内容进行判断分析以及处理
            - StripPrefix=1 #转发之前去掉path中第一层路径,例如nacos
#假如输入的地址是http://localhost:9000/nacos/provider/echo/aaa,请求过来了
#1、经过    predicates: ###断言(谓词)————看地址的端口号后面的内容和它是不是匹配/一样的   假如匹配进入2、
#2、经过    filters: ##网关过滤器,去掉path中第一层路径 输入的地址路径就变成了http://localhost:9000/provider/echo/aaa
#3、转发    uri:    真正转发的路径就变成了http://localhost:8081/provider/echo/aaa,端口号也变了


其中:路由(Route) 是 gateway 中最基本的组件之一,表示一个具体的路
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值