SpringCloud Zuul网关功能实现解析

作者:玉天恒 时间:2022-09-12 14:30:31 

简介

API Gateway,时系统的唯一对外的入口,介于客户端和服务端之间的中间层,处理非业务功能,

提供路由请求,鉴权,监控,缓存,限流等功能

  • 统一接入

    • 智能路由

    • AB测试、灰度测试

    • 负载均衡、容灾处理

    • 日志埋点(类似 Nignx日志)

  • 流量监控

    • 限流处理

    • 服务降级

  • 安全防护

    • 鉴权处理

    • 监控

    • 机器网终隔离

1.添加依赖

注意SpringBoot和SpringCloud版本兼容


<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<!-- fastjson -->
<dependency>
 <groupId>com.alibaba</groupId>
 <artifactId>fastjson</artifactId>
 <version>1.2.28</version>
</dependency>

2.添加启动类注解@EnableZuulProxy


import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableZuulProxy
public class ZuulgatewayApplication {

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

}

3.修改application.yml配置

默认访问规则

http://gateway:port/service-id/**


server:
port: 9000
eureka:
client:
 serviceUrl:
  defaultZone: http://localhost:8761/eureka/

spring:
application:
 name: zuul-gateway

#自定义路由映射
#order-service是订单服务的名称,访问路径为
#旧:  http://localhost:9000/order-serice/api/v1/order/find
#新:  http://localhost:9000/apigateway/order/api/v1/order/find
zuul:
routes:
#方法一:
#  product-service: /apigateway/product/**
#  order-service: /apigateway/order/**
#方法二:
 product-route:    #路由名称,可以任意取
  service-id: product-service
  path: /apigateway/product/**
 order-route:
  service-id: order-service
  path: /apigateway/order/**
#忽略整个服务,不对外提供接口
#多个服务用逗号隔开product-service,order-service
#即不能用http://localhost:9000/order-serice/api/v1/order/find方式访问
# ignored-services: product-service
#正则表达式忽略多个服务
ignored-patterns: /*-service/**
sensitive-headers:

#zuul使用Ribbon负载均衡,所以要配置ribbon超时时间,否则很短
host:
 connect-timeout-millis: 15000 #HTTP连接超时要比Hystrix的大
 socket-timeout-millis: 60000  #socket超时
ribbon:
ReadTimeout: 10000
ConnectTimeout: 10000

4.Zuul网关注意事项

默认情况,请求头header不会传递Cookie,Set-Cookie,Authorization信息,这些信息会显示为空

如果需要传递,则修改application.yml配置

zuul: sensitive-headers:

5.访问路径

http://127.0.0.1:9000/apigateway/product/api/v1/product/find?id=1

http://127.0.0.1:9000/apigateway/order/api/v1/order/test?product_id=1

图1

SpringCloud Zuul网关功能实现解析

来源:https://www.cnblogs.com/tianhengblogs/p/12495370.html

标签:Spring,Cloud,Zuul,网关
0
投稿

猜你喜欢

  • Idea2020.2创建JavaWeb项目(部署Tomcat)方法详解

    2023-11-02 13:29:52
  • Mybatis-plus多数据源配置的两种方式总结

    2023-07-24 05:22:48
  • Java中通过Class类获取Class对象的方法详解

    2021-11-09 17:12:57
  • Java源码解析之object类

    2023-11-05 00:46:28
  • Springboot整合redis实现发布订阅功能介绍步骤

    2021-11-23 16:42:26
  • 深入解析Java中的Classloader的运行机制

    2023-07-16 11:47:59
  • SpringBoot + validation 接口参数校验的思路详解

    2023-10-09 11:59:12
  • Java语言求解完美数代码分析

    2023-01-28 10:17:58
  • Spring Boot使用profile如何配置不同环境的配置文件

    2023-11-25 12:52:36
  • java并发编程之ThreadLocal详解

    2023-03-15 11:44:33
  • SpringBoot应用启动流程源码解析

    2023-11-25 00:03:24
  • Java String 字符串常量池解析

    2023-01-08 19:44:05
  • java模拟TCP通信实现客户端上传文件到服务器端

    2023-11-26 10:14:49
  • Java之Rsync并发迁移数据并校验详解

    2023-07-17 23:01:22
  • Dwr3.0纯注解(纯Java Code配置)配置与应用浅析二之前端调用后端

    2023-08-19 17:32:33
  • java 非常好用的反射框架Reflections介绍

    2022-11-25 01:25:52
  • Java面试题及答案集锦(基础题122道,代码题19道)

    2023-11-25 12:36:17
  • Spring常用注解汇总

    2022-12-19 16:26:03
  • Java超全面梳理内部类的使用

    2021-09-06 11:24:07
  • 详解SpringBoot中如何使用布隆过滤器

    2023-11-10 17:43:06
  • asp之家 软件编程 m.aspxhome.com