SpringCloud Zuul网关功能实现解析
作者:玉天恒 发布时间:2022-09-12 14:30:31
标签:Spring,Cloud,Zuul,网关
简介
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
来源:https://www.cnblogs.com/tianhengblogs/p/12495370.html
0
投稿
猜你喜欢
- Java泛型映射不同的值类型详解前言:一般来说,开发人员偶尔会遇到这样的情形: 在一个特定容器中映射任意类型的值。然而Java 集合API只
- 基于 springboot+vue的测试平台开发一、前端环境搭建在前端框架vue-element-admin这个项目中,有一个简洁轻量型的项
- 简介FTP 简介FTP 即 文件传输协议(英语:File Transfer Protocol 的缩写)是一个用于计算机网络上在客户端和服务器
- SpringBoot 集成 activiti 基础环境搭建添加依赖<dependency> <groupId&g
- 本文实例讲述了Java基于Tcp的基础聊天功能。分享给大家供大家参考,具体如下:最基础的聊天,用户端和服务器端每次说一句,而且严格规定了先后
- java 使用异常的好处总结一、分析Java异常处理机制确实比较慢,这个“比较慢”是相对于诸如String、Integer等对象来说,单单从
- substring(参数)是java截取字符串的一个方法。它有两种传参的方式:第一种:public String substring(int
- 目前常用的ORM框架有 Mybatis(batis)、MybatisPlus,Hibernate、Jpa等几个框架,今天就简单介绍一下搭建M
- 工作笔记(在不知道json的key时如何获取当前json的keys)String json="{'name':
- 背景我在准备使用 JVM 的命令时候观察程序的动态,但是发现 Main 函数启动就退出了,所以也没办法直接观察,于是想到了如何让 Main
- 前言最近因为同事bean配置的问题导致生产环境往错误的redis实例写入大量的数据,差点搞挂redis。经过快速的问题定位,发现是同事新增一
- Java 开发语言中实现HTTP请求的方法主要有两种:一种是JAVA的标准类HttpUrlConnection,比较原生的实现方法;另一种是
- 本文提供了基于MD5加密16位和32位的方法,具体内容如下import java.io.IOException;import java.ma
- java里有数字long来表示大的整数,如果两个数字的范围超过了long,要做加法算法怎么做呢?这个问题在面试中经常碰到,如果之前没有经历的
- 一、数据输出SpringMVC将数据携带给页面的储存工具,有三种,map,ModelMap,model,它们在底层实质还是使用到了Bindi
- 这一篇写一下springboot整合solr,代码已经上传到github,传送门。1、新建core并配置schemasolr create
- jmap命令可以打印java进程的JVM堆信息,今天在某台机器上运行该命令查看 19560进程的堆信息jmap -heap 19560出现以
- 目录一、二叉树的顺序存储1.堆的存储方式2.下标关系二、堆(heap)1.概念2.大/小 根堆2.1小根堆2.2大根堆3.建堆操作3.1向下
- 日期、数字格式化显示,是web开发中的常见需求,spring mvc采用XXXFormatter来处理,先看一个最基本的单元测试:packa
- Java8 LocalDateTime与timestamp转换将timestamp转为LocalDateTimepublic LocalDa