1. 禁用过滤器

# zuul.<SimpleClassName>.<filterType>.disable=true
# 例如禁用 自定义的过滤器
zuul.MyFilter.pre.disable=true

2. 路由的映射

  方法1:

zuul.routes.spring-cloud-provider=/provider/**
zuul.routes.spring-cloud-consumer=/consumer/**

  说明:spring-cloud-provider服务名称,对其进行路由,一个*代表匹配一层,二个**代表匹配所有

  测试:http://localhost:9876/consumer/user/1

  测试:http://localhost:9876/provider/api/user/1

  方法2:

zuul.routes.provider1.path=/provider1/**
zuul.routes.provider1.service-id=spring-cloud-provider
zuul.routes.consumer1.path=/consumer1/**
zuul.routes.consumer1.service-id=spring-cloud-consumer

  说明:provider1和consumer1代表id,自己定,只要不重复即可。

  测试:http://localhost:9876/consumer/user/1

  测试:http://localhost:9876/provider/api/user/1

3. 禁用服务名进行访问

zuul.ignored-services=/spring-cloud-provider
# zuul.ignored-services=/* 禁用所有

4. strip-prefix(代理前缀)的灵活使用

#strip-prefix 的配置()
# 默认为true,(代理前缀默认会从请求路径中移除)
zuul.routes.provider1.strip-prefix=false
zuul.routes.provider1.path=/api/**
zuul.routes.provider1.service-id=spring-cloud-provider
zuul.routes.consumer1.strip-prefix=false
zuul.routes.consumer1.path=/consumer1/**
zuul.routes.consumer1.service-id=spring-cloud-consumer1

  测试:http://localhost:9876/provider/api/user/1

5. sensitive-headers属性(不传递给下游的服务应用)

zuul.routes.provider1.sensitive-headers=token
# 默认值 Cookie, Set-Cookie,Authorization
# 注意:如果不禁用服务名的情况下,通过服务名,这个设置是无效的

6. 脱离注册中心,不使用注册中心

# 禁用注册中心
ribbon.eureka.enabled=false # 不实现负载均衡
#zuul.routes.wangx.path=/**
#zuul.routes.wangx.url=http://baidu.com #实现负载均衡
zuul.routes.wangx.path=/**
zuul.routes.wangx.service-id=wangx-x
wangx-x.ribbon.listOfServers=http://baidu.com,http://spring.io

7. 自定义路由策略

  使用正则表达式,自定义bean

  @Bean
public PatternServiceRouteMapper serviceRouteMapper() {
return new PatternServiceRouteMapper("(?<name1>^.*)-(?<name2>c.*)-(?<name3>c.+$)", "${name1}-${name2}-provider") {
@Override
public String apply(final String serviceId) {
String route = super.apply(serviceId);
System.out.println(route + " -> " + serviceId);
return route;
}
};
}

  打印:

  spring-cloud-provider -> spring-cloud-consumer

  spring-cloud-zuul -> spring-cloud-zuul

  spring-cloud-provider -> spring-cloud-provider

  说明:将provider转发到consumer

8. ignored-parrterns 说明

  zuul.ignored-patterns=/**/api/**

  忽略含有api的路径的url

9. legacy说明

  zuul.routers.legacy.path=/**

  zuul.routers.legacy.url=http://baidu.com

  #若前面的路由匹配不到,那么就使用这个

10. 上传大文件

  提供者代码

 @RequestMapping("/upload")
public String upload(@RequestParam("file")MultipartFile file) throws IOException {
File file1 = new File("F:/" + file.getOriginalFilename());
System.out.println("开始上传文件......");
FileCopyUtils.copy(file.getBytes(),file1);
return "SUCCESS";
}

  设置上传文件最大值

# 上传文件最大值
spring.servlet.multipart.max-file-size=1000MB
spring.servlet.multipart.max-request-size=1000MB

  测试:curl -F "file=@eclipse.zip" http://localhost:8976/api/user/upload

 使用隐藏连接/zuul/

  curl -F "file=@eclipse.zip" http://localhost:8976/zuul/api/user/upload

  设置

  

hystrix.command.defautl.execution.isolation.thread.timeoutInMilliseconds=6000
#全局设置
ribbon.ConnectTimeout=6000
ribbon.ReadTimeout=6000
# 单独设置
provider1.ribbon.ConnectTimeout=300

11. 异常处理

  

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream; import org.springframework.cloud.netflix.zuul.filters.route.ZuulFallbackProvider;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.client.ClientHttpResponse;
import org.springframework.stereotype.Component; @Component
public class ProviderFallbackProvider implements ZuulFallbackProvider { @Override
public String getRoute() {
return "spring-cloud-provider";
} @Override
public ClientHttpResponse fallbackResponse() {
return new ClientHttpResponse() { @Override
public HttpStatus getStatusCode() throws IOException {
return HttpStatus.OK;
} @Override
public int getRawStatusCode() throws IOException {
return 200;
} @Override
public String getStatusText() throws IOException {
return "OK";
} @Override
public void close() { } @Override
public InputStream getBody() throws IOException {
return new ByteArrayInputStream((getRoute()+ " is fallback").getBytes());
} @Override
public HttpHeaders getHeaders() {
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
return headers;
}
};
}
}

SpringCloud学习笔记(20)----Spring Cloud Netflix之服务网关Zuul的各种姿势的更多相关文章

  1. SpringCloud学习笔记(19)----Spring Cloud Netflix之服务网关Zuul自定义过滤器

    zuul不仅只是路由,还可以自定义过滤器来实现服务验证. 实现案例:自定义过滤器,检验头部是否带有token,如果token=wangx,则通过校验,若不存在或不为wangx则返回提示token错误. ...

  2. SpringCloud学习笔记(17)----Spring Cloud Netflix之服务网关Zuul的使用

    1. 什么时候Zuul? Zuul是一个基于jvm路由和服务端的负载均衡器,在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架. 路由功能:相当于nginx的反向代理 比如: / 可能需要映射到 ...

  3. SpringCloud学习笔记(18)----Spring Cloud Netflix之服务网关Zuul原理

    1. Zuul的工作机制 Zuul提供了一个框架,可以对过滤器进行动态的加载,编译,运行.过滤器之间没有直接的相互通信,他们是通过一个RequestContext的静态类来进行数据传递的.Requet ...

  4. Spring Cloud(十):服务网关zuul(转)

    前面的文章我们介绍了,Eureka用于服务的注册于发现,Feign支持服务的调用以及均衡负载,Hystrix处理服务的熔断防止故障扩散,Spring Cloud Config服务集群配置中心,似乎一个 ...

  5. springCloud学习-消息总线(Spring Cloud Bus)

    1.简介 Spring Cloud Bus 将分布式的节点用轻量的消息代理连接起来.它可以用于广播配置文件的更改或者服务之间的通讯,也可以用于监控.本文要讲述的是用Spring Cloud Bus实现 ...

  6. SpringCloud学习笔记(二):微服务概述、微服务和微服务架构、微服务优缺点、微服务技术栈有哪些、SpringCloud是什么

    从技术维度理解: 微服务化的核心就是将传统的一站式应用,根据业务拆分成一个一个的服务,彻底 地去耦合,每一个微服务提供单个业务功能的服务,一个服务做一件事, 从技术角度看就是一种小而独立的处理过程,类 ...

  7. SpringCloud学习笔记(四):Eureka服务注册与发现、构建步骤、集群配置、Eureka与Zookeeper的比较

    简介 Netflix在设计Eureka时遵守的就是AP原则 拓展: 在分布式数据库中的CAP原理 CAP原则又称CAP定理,指的是在一个分布式系统中,Consistency(一致性). Availab ...

  8. SpringCloud学习笔记(1)----认识微服务与SpringCloud

    1.  微服务是什么? 微服务是一种由多个服务组成的集合体,它属于一种软甲架构,在微服务中,它的每个服务都是独立存在的,微服务是一种去中心化的思想. 它具有开发简单,技术栈灵活,服务独立解耦,可用性高 ...

  9. SpringCloud学习笔记-Eureka基础

    Spring Cloud Eureka是Spring Cloud Netflix微服务套件中的一部分,它基于Netflix Eureka做了二次封装,主要负责完成微服务架构中的微服务治理功能. 服务端 ...

随机推荐

  1. vue-cli 3.0 安装和创建项目流程

    使用前我们先了解下3.0较2.0有哪些区别 一.3.0 新加入了 TypeScript 以及 PWA 的支持二.部分命令发生了变化: 1.下载安装  npm install -g vue@cli 2. ...

  2. 关于app夜间模式那点事

    大半年没写过代码了 一直在忙一些其他的事情  这几天想起来看了一点  心惊肉跳的 发现好陌生  所以打算今后慢慢的拾起来  往深度和广度去发展 发现好久之前写的一个微博项目  有一个夜间模式的功能没有 ...

  3. Obj文件和Bin文件

    本文导读:在用visual studio 编程时,会看到项目文件中含有bin和obj这两个文件夹,那么这两个文件夹具体包含一些什么东西的,具体作用是什么? 一.Bin文件夹 1.用来保存项目生成后程序 ...

  4. 通过adb 设置、删除、获取 系统配置值。

    通过adb 设置.删除.获取 系统配置值. Key定义在:frameworks\base\core\java\android\provider\Settings.java adb shell sett ...

  5. luogu p1003

    P1003 题意 经过多个矩形(1e3)覆盖后后某个坐标属于那个矩形(仅仅是一次询问) 大水题,直接的做法,从后向前处理矩形是否覆盖查询的点,若覆盖,则是该矩形编号 题解 int get_num(){ ...

  6. POJ 1988 Cube Stacking( 带权并查集 )*

    POJ 1988 Cube Stacking( 带权并查集 ) 非常棒的一道题!借鉴"找回失去的"博客 链接:传送门 题意: P次查询,每次查询有两种: M x y 将包含x的集合 ...

  7. [读书笔记] Python 数据分析 (十一)经济和金融数据应用

    resample: 重采样函数,可以按照时间来提高或者降低采样频率,fill_method可以使用不同的填充方式. pandas.data_range 的freq参数枚举: Alias Descrip ...

  8. u-boot启动代码start.S详解

    (1)定义入口.由于一个可执行的Image必须有一个入口点,并且只能有一个全局入口,通常这个入口放在ROM(Flash)的0x0地址,因此,必须通知编译器以使其知道这个入口,该工作可通过修改连接器脚本 ...

  9. myeclipse导入工程 Some projects cannot be imported because they already exist in the workspace

    问题描述: 1 第一次从外部导入工程或者新建工程,成功: 2 删除该工程,但是没有选择delete project contents on disk 3 再次需要该工程,导入该工程时出现警告:Some ...

  10. ASP.NET-GUID扩展类使用

    在NUGET上有一个GUID的类,安装试用一下它的方法 将string转为guid对象 Guid ad = new Guid("{99009327-15D2-4A69-B015-BEAC11 ...