博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java B2B2C 源码 多级分销springmvc mybatis多租户电子商城系统---服务网关zuul
阅读量:5896 次
发布时间:2019-06-19

本文共 1589 字,大约阅读时间需要 5 分钟。

  1. Zuul是什么

微服务场景下,每一个微服务对外暴露了一组细粒度的服务。客户端的请求可能会涉及到一串的服务调用,如果将这些微服务都暴露给客户端,那么会增加客户端代码的复杂度。需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码 一零三八七七四六二六

参考GOF设计模式中的Facade模式,将细粒度的服务组合起来提供一个粗粒度的服务,所有请求都导入一个统一的入口,那么整个服务只需要暴露一个api,对外屏蔽了服务端的实现细节,也减少了客户端与服务器的网络调用次数。这就是api gateway。

有了api gateway之后,一些与业务关系并不大的通用处理逻辑可以从api gateway中剥离出来,api gateway仅仅负责服务的编排与结果的组装。

Spring Cloud Netflix的Zuul组件可以做反向代理的功能,通过路由寻址将请求转发到后端的粗粒度服务上,并做一些通用的逻辑处理。

2.Zuul 能做什么

Zuul可以通过加载动态过滤机制,从而实现以下各项功能:

验证与安全保障: 识别面向各类资源的验证要求并拒绝那些与要求不符的请求。

审查与监控: 在边缘位置追踪有意义数据及统计结果,从而为我们带来准确的生产状态结论。

动态路由: 以动态方式根据需要将请求路由至不同后端集群处。

压力测试: 逐渐增加指向集群的负载流量,从而计算性能水平。

负载分配: 为每一种负载类型分配对应容量,并弃用超出限定值的请求。

静态响应处理: 在边缘位置直接建立部分响应,从而避免其流入内部集群。

多区域弹性: 跨越AWS区域进行请求路由,旨在实现ELB使用多样化并保证边缘位置与使用者尽可能接近。

3.怎么使用Zuul Spring Cloud Zuul路由是微服务架构的不可或缺的一部分,提供动态路由,监控,弹性,安全等的边缘服务。Zuul是Netflix出品的一个基于JVM路由和服务端的负载均衡器。

下面我们通过代码来了解Zuul是如何工作的

1.简单使用

1、添加依赖

org.springframework.cloud
spring-cloud-starter-zuul
复制代码

引入spring-cloud-starter-zuul包

2、配置文件

spring.application.name=gateway-service-zuulserver.port=8888#这里的配置表示,访问/it/** 直接重定向到http://www.ityouknow.com/**zuul.routes.baidu.path=/it/**zuul.routes.baidu.url=http://www.ityouknow.com/ ```3、启动类复制代码

@SpringBootApplication @EnableZuulProxy public class GatewayServiceZuulApplication {       public static void main(String[] args) {         SpringApplication.run(GatewayServiceZuulApplication.class, args);     } }

启动类添加@EnableZuulProxy,支持网关路由。史上最简单的zuul案例就配置完了。 [java B2B2C 源码 多级分销springmvc mybatis多租户电子商城系统](https://2147775633.iteye.com/blog/2434341)复制代码

转载于:https://juejin.im/post/5cb68ecfe51d456e714085a8

你可能感兴趣的文章
用JSP实现的商城购物车模块
查看>>
C++ Primer Plus第6版18个重点笔记
查看>>
百度地图 孪生姐妹地图
查看>>
电子技术·笔记6(2013-05\06)
查看>>
进制间的相互转化
查看>>
SQL server 性能调优
查看>>
android开发 更新升级安装到一半自动闪退
查看>>
Linux安装telnet
查看>>
linux 标准I/O (二)
查看>>
量子纠缠
查看>>
[翻译svg教程]svg 中的g元素
查看>>
【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物...
查看>>
【DeepLearning】Exercise:Self-Taught Learning
查看>>
【leetcode】Median of Two Sorted Arrays(hard)★!!
查看>>
IOS 消息机制(NSNotificationCenter)
查看>>
JAVA 设计模式 策略模式
查看>>
openstack nova修改实例路径,虚拟磁盘路径
查看>>
java.sql.SQLException: Lock wait timeout exceeded --转
查看>>
使用C#进行图像处理的几种方法(转)
查看>>
Blob
查看>>