SpringCloud学习笔记(4)——Zuul
参考Spring Cloud官方文档第19章
19.Router and Filter: Zuul
路由是微服务架构的一部分。例如,"/"可能映射到你的web应用,"/api/users"可能映射到你的user服务,"/api/shop"可能映射到你的shop服务。Zuul是一个基于JVM的路由器和服务端的负载均衡器。
data:image/s3,"s3://crabby-images/4f994/4f99449cb4719132ef614ef3aa559ce7f24d7e2b" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
Zuul的规则引擎可以用任何JVM语言来写,内置的支持Java和Groovy。
注意:配置属性zuul.max.host.connections已经被两个新的属性所替代,zuul.host.maxTotalConnections和zuul.host.maxPerRouteConnections,它们的默认值分别是200和20。
19.1How to Include Zuul
data:image/s3,"s3://crabby-images/2563d/2563d64336859d8bad7fb18d53806d53b391d291" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
19.2Embedded Zuul Reverse Proxy
Spring Cloud已经创建了一个内嵌的Zuul代理来方便进行通用的开发,它通常的使用场景是一个UI应用想要代理一个或者多个后端服务的调用。
为了使用它,需要在Spring Boot的运行主类上加@EnableZuulProxy注解,这样它就可以转发本地调用给合适的服务。按照惯例,一个ID叫做"users"的服务,将会从proxy那里收到定位到/users的请求。Proxy使用Ribbon来定位一个实例进而转发,并且所有的请求都加上了断路器,一旦断路器打开,proxy将不再尝试连接这个服务。
为了跳过一些服务,可以设置zuul.ignored-services。如果一个服务既匹配忽略规则,又明确的包含在路由映射中,那么它将不被忽略。例如
data:image/s3,"s3://crabby-images/0e639/0e6397f0714a7f3197793e81d9032de7909e6b58" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
为了更好的控制路由,你可以指定服务ID和路径,例如:
data:image/s3,"s3://crabby-images/b773c/b773cd3ef40db8a28340b9e621b0f2f91b3b5cc5" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
另一种方式是配合Ribbon来实现多个实例的路由访问
data:image/s3,"s3://crabby-images/61210/6121084ad1a0f18197c129c3200b20da7e597d46" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
19.15.3 @EnableZuulProxy
VS @EnableZuulServer
Spring Cloud Netflix基于开启Zuul的注解提供了大量的过滤器。@EnableZuulProxy包含所有安装在@EnableZuulServer中的注解,如果你想使用空的Zuul,请使用@EnableZuulServer
data:image/s3,"s3://crabby-images/f7ee7/f7ee7fce249db7052fa0d95b29e11847c557ddea" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/fa7f0/fa7f02688d6c922202787122aeb9c7dd5c353ca9" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
一言不合就上代码
这次新建两个服务提供方,一个叫user-service,另一个叫order-service。至于配置和pom都和以前一样,主要是引入eureka-client,然后配置端口之类的。
data:image/s3,"s3://crabby-images/f02a7/f02a741b3914f5525ad7e1a6065324793d460efc" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
然后,再建一个工程zuul-demo。这个工程没啥特别的,并没有做特殊的配置,没有做路由配置,但是仍然具有路由功能。
data:image/s3,"s3://crabby-images/fe4ce/fe4ce3e4139e68f26c44c2bc51026a7486a273c6" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/14512/14512888c0c880f1a1b52e208ef34c833f8b2f55" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/f0426/f0426ea0c5a9589e3072d25580e09567f89562a2" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
启动这4个工程,如图
data:image/s3,"s3://crabby-images/aa2f8/aa2f8978924851554e008307208c5414169b1c0e" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
接下来就可以访问了
data:image/s3,"s3://crabby-images/cf172/cf172caa6315413453e1413115a9199c39dbadbe" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/81162/811626e0d327b23263f782438e7f7de87419399c" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
可以看到,主机是localhost:8090,这是zuul-demo这个工程,也就是我们通过zuul-demo可以访问到order-service和user-service上的服务,这就是网关的作用。
有一点很重要,网关是对外的。而且,应该注意到,这里我们并没有配置任何路由规则,但是仍然可以正确的路由,这一切得归功于Eureka,如果没有注册中心的话又想路由的话就得配路由规则了。不过,保险起见,还是明确指定路由规则吧。
接下来配个规则
data:image/s3,"s3://crabby-images/be0ad/be0add1b07bc239a1a19a6982c93962e80b551a6" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/10cae/10cae7a64907bc854c94b56413718023c3876457" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
过滤器
19.15.7How to Write a Pre Filter
data:image/s3,"s3://crabby-images/774e6/774e62a700e56d19e96e5733b6518cc794b8d0bd" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/1fcb8/1fcb883aac7ceeea0f5f593791b8b8f0755f2db2" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
data:image/s3,"s3://crabby-images/ce179/ce179f77d70b594f95d50b00668cd4d8163afdec" alt="SpringCloud学习笔记(4)——Zuul SpringCloud学习笔记(4)——Zuul"
参考
http://blog.didispace.com/spring-cloud-starter-dalston-6-2/
http://blog.didispace.com/spring-cloud-starter-dalston-6-3/