公司目前使用的是dubbo方式实现微服务,想试水改造接口层服务为Spring Cloud, 以下是网络拓补图。

第一层负载均衡可以用nginx或者zuul(即有2层zuul), 本图画的是nginx。

Zuul的作用就是路由转发和过滤, 即将请求转发到微服务或拦截请求; Zuul默认集成了负载均衡功能。

下面创建一个zuul工程:

打开IntelliJ Idea ---> New Project ---> 选择Spring Initializr ---> 设置包名 ---> 勾选web、zuul、Eureka Discovery -> 设置存储路径。

一、 路由:

在入口类添加注解@EnableZuulProxy, 即打开zuul功能;


  1. @SpringBootApplication
  2. @EnableEurekaClient
  3. @EnableZuulProxy
  4. public class SpringZuulDemoApplication {
  5. public static void main(String[] args) {
  6. SpringApplication.run(SpringZuulDemoApplication.class, args);
  7. }
  8. }

修改配置文件, 指定注册中心地址和路由规则zuul.routes, 建议使用微服务名称命名子节点。

启动Eureka注册中心、service-hello1、service-ribbon-consumer1和当前服务。

在浏览器输入:http://localhost:13000/servicehello1/hello?param=“test”

以/servicehello1/开头的请求会被转发到service-hello1服务, 以/consumer1/开头的请求会被转发到service-ribbon-consumer1服务。 PS: 如果是集群服务, 那么会转发到不同的ip/port。

http://localhost:13000/servicehello1/hello?param=“test”最终会执行doHello函数。


  1. @RestController(value = "/servicehello1")
  2. public class ZuulTestController {
  3. @Value("${server.port}")
  4. String port; //在application.yml文件里赋的值
  5. @RequestMapping("helloworld")
  6. public String doHello(@RequestParam String param) {
  7. return "servicehello1! " + param + ":" + "port is " + port;
  8. }
  9. }

二、过滤,  zuul可以实现验签功能和自定义过滤功能, 功能跟SpringMVC的拦截器一样。

在zuuldemo工程里新建一个Java类, PS:可以定义多个过滤类,设置不同的filterOrder(即执行时序), 基类都是ZuulFilter;

下面定义2个拦截器类, filterOrder值为0和1。


  1. public class DemoFilter extends ZuulFilter {
  2. private static Logger logger = LoggerFactory.getLogger(DemoFilter.class);
  3. @Override
  4. public String filterType() {
  5. return "pre"; //枚举值:pre, routing, post, error
  6. }
  7. @Override
  8. public int filterOrder() {
  9. return 1; //优先级, 0是最高优先级即最先执行
  10. }
  11. @Override
  12. public boolean shouldFilter() {
  13. return true; //写逻辑,是否需要执行过滤。true会执行run函数,false不执行run函数
  14. }
  15. @Override
  16. public Object run() {
  17. logger.info("----------------this is DemoFilter----------");
  18. RequestContext ctx = RequestContext.getCurrentContext();
  19. HttpServletRequest request = ctx.getRequest();
  20. logger.info(String.format("%s %s", request.getMethod(), request.getRequestURL().toString()));
  21. Object accessToken = request.getParameter("token");
  22. if(accessToken == null) { //判断释放有token自动
  23. logger.warn("token is empty");
  24. ctx.setSendZuulResponse(false);
  25. ctx.setResponseStatusCode(401);
  26. try {
  27. ctx.getResponse().getWriter().write("token is empty");
  28. }catch (Exception e){}
  29. return null;
  30. }
  31. return null;
  32. }
  33. }


  1. @Component
  2. public class Demo1Filter extends ZuulFilter{
  3. private static Logger logger = LoggerFactory.getLogger(DemoFilter.class);
  4. @Override
  5. public String filterType() {
  6. return "pre"; //枚举值:pre, routing, post, error
  7. }
  8. @Override
  9. public int filterOrder() {
  10. return 0; //优先级, 0是最高优先级即最先执行
  11. }
  12. @Override
  13. public boolean shouldFilter() {
  14. return true; //写逻辑,是否需要执行过滤。true会执行run函数,false不执行run函数
  15. }
  16. @Override
  17. public Object run() {
  18. logger.info("----------------this is Demo1Filter----------");
  19. return null;
  20. }
  21. }

filterType:表示过滤类型。 pre表示路由之前, routing表示路由当中, post表示路由之后, error表示路由发生错误。

filterOrder: 执行时序, 值是0,1,2....N等自然数。 0的优先级最高,即最先执行。

shouldFilter: 是否需要执行run函数。

run:拦截器的具体实现;

在浏览器输入: localhost:13000/servicehello1/hello?param="test"会显示拦截器的返回值, 即请求被成功拦截。


  1. 2017-11-28 13:04:07.837 INFO 28824 --- [trap-executor-0] c.n.d.s.r.aws.ConfigClusterResolver : Resolving eureka endpoints via configuration
  2. 2017-11-28 13:05:31.720 INFO 28824 --- [io-13000-exec-3] com.example.springzuuldemo.DemoFilter : ----------------this is Demo1Filter----------
  3. 2017-11-28 13:05:31.720 INFO 28824 --- [io-13000-exec-3] com.example.springzuuldemo.DemoFilter : ----------------this is DemoFilter----------
  4. 2017-11-28 13:05:31.720 INFO 28824 --- [io-13000-exec-3] com.example.springzuuldemo.DemoFilter : GET http://localhost:13000/servicehello1/hello
  5. 2017-11-28 13:05:31.761 INFO 28824 --- [io-13000-exec-3] s.c.a.AnnotationConfigApplicationContext : Refreshing

在浏览器输入: localhost:13000/servicehello1/hello?param="test"&param="123" , 即符合拦截器规则后执行了service-hello1服务的hello接口。

          

综上, zuul包装了微服务, 微服务对调用者是透明的, 即调用者不知道访问了哪个微服务。 zuul可以理解为路由器和过滤器的综合体。

参考代码:http://download.csdn.net/download/brycegao321/10138936

SpringCloud学习笔记-zuul网关的更多相关文章

  1. 011 SpringCloud 学习笔记7-----Zuul网关

    1.Zuul网关概述 通过前面的学习,使用Spring Cloud实现微服务的架构基本成型,大致是这样的: 我们使用Spring Cloud Netflix中的Eureka实现了服务注册中心以及服务注 ...

  2. SpringCloud学习笔记(6):使用Zuul构建服务网关

    简介 Zuul是Netflix提供的一个开源的API网关服务器,SpringCloud对Zuul进行了整合和增强.服务网关Zuul聚合了所有微服务接口,并统一对外暴露,外部客户端只需与服务网关交互即可 ...

  3. SpringCloud学习笔记:服务支撑组件

    SpringCloud学习笔记:服务支撑组件 服务支撑组件 在微服务的演进过程中,为了最大化利用微服务的优势,保障系统的高可用性,需要通过一些服务支撑组件来协助服务间有效的协作.各个服务支撑组件的原理 ...

  4. SpringCloud学习笔记(2):使用Ribbon负载均衡

    简介 Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡工具,在注册中心对Ribbon客户端进行注册后,Ribbon可以基于某种负载均衡算法,如轮询(默认 ...

  5. SpringCloud学习笔记(3):使用Feign实现声明式服务调用

    简介 Feign是一个声明式的Web Service客户端,它简化了Web服务客户端的编写操作,相对于Ribbon+RestTemplate的方式,开发者只需通过简单的接口和注解来调用HTTP API ...

  6. SpringCloud学习笔记(4):Hystrix容错机制

    简介 在微服务架构中,微服务之间的依赖关系错综复杂,难免的某些服务会出现故障,导致服务调用方出现远程调度的线程阻塞.在高负载的场景下,如果不做任何处理,可能会引起级联故障,导致服务调用方的资源耗尽甚至 ...

  7. SpringCloud学习笔记(5):Hystrix Dashboard可视化监控数据

    简介 上篇文章中讲了使用Hystrix实现容错,除此之外,Hystrix还提供了近乎实时的监控.本文将介绍如何进行服务监控以及使用Hystrix Dashboard来让监控数据图形化. 项目介绍 sc ...

  8. SpringCloud学习笔记(7):使用Spring Cloud Config配置中心

    简介 Spring Cloud Config为分布式系统中的外部化配置提供了服务器端和客户端支持,服务器端统一管理所有配置文件,客户端在启动时从服务端获取配置信息.服务器端有多种配置方式,如将配置文件 ...

  9. SpringCloud学习之zuul

    一.为什么要有网关 我们先看一个图,如果按照consumer and server(最初的调用方式),如下所示 这样我们要面临如下问题: 1. 用户面临着一对N的问题既用户必须知道每个服务.随着服务的 ...

随机推荐

  1. Redis学习笔记--String(四)

    Redis的第一个数据类型string 1.命令 1.1赋值 语法:SET key value Set key value; > OK 1.2取值 语法:GET key > get tes ...

  2. js+html实现遮罩层效果(收藏哦)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <script ty ...

  3. VS2012调试C++工程DLL

    1.C++工程属性对话框 2.配置属性: (1)常规:输出目录:..\Bin\WFCrawler(调用DLL的工程)            中间目录:..\Bin\WFCrawler(调用DLL的工程 ...

  4. [Angular2 Form] Angular 2 Template Driven Form Custom Validator

    In this tutorial we are going to learn how we can also implement custom form field validation in Ang ...

  5. thinkphp5 tp5 七牛云 上传图片

    七牛sdk地址https://files.cnblogs.com/files/zonglonglong/qiniu-php-sdk-7.2.2.rar 首先下载php的sdk将文件夹放到vendor ...

  6. ldap chinese guide

    OpenLDAP2.4管理员指南 http://wiki.jabbercn.org/index.php/OpenLDAP2.4%E7%AE%A1%E7%90%86%E5%91%98%E6%8C%87% ...

  7. ios开发核心动画七:核心动画与UIView动画的区别

    /** UIView与核心动画区别?(掌握) 1.核心动画只作用在layer. 2.核心动画看到的都是假像,它并没有去修改UIView的真实位置. 什么时候使用核心动画? 1.当不需要与用户进行交互, ...

  8. 调用另一个Activity 分类: H1_ANDROID 2013-09-22 14:11 2217人阅读 评论(0) 收藏

    参考自Google官方文档Traning/Getting Started/Building a simple user interface, Startinganother activity,http ...

  9. ios开发之手势处理 之手势识别一

    #import "ViewController.h" @interface ViewController ()<UIGestureRecognizerDelegate> ...

  10. An Overview of Cisco IOS Versions and Naming

    An Overview of Cisco IOS Versions and Naming http://www.ciscopress.com/articles/article.asp?p=210654 ...