SpringCloud Zuul基本使用方法汇总
SpringCloudZuul是SpringCloud系列的网关实现,具有均衡负载,将非业务性校验剥离出来,使微服务专注于业务的一个组件
使用Zuul网关后,所有的请求都通过网络进行转发,所以所有的请求都隐藏了自己的主机及端口信息,而是统一使用Zuul网关的主机及端口号作为请求入口,Zuul网关在收到请求后,会根据serviceId自动发现目标微服务地址,然后将请求转发到目标微服务上进行处理.
Zuul仍然是开箱即用工具系列,因此仍然适用4部曲套路:
1.引入依赖:spring-cloud-starter-zuul
2.添加支持:在启动类上添加@EnableZuulProxy
3.具体使用:zuul会自动从注册中心上发现微服务,并创建网关代理
4.按需配置:如果集成了Eureka,则Zuul会自动从注册中心获取所有应用,自动根据serviceId建立转发规则,如果没有集成注册中心,则需要配置一下:
4.1指定转发的匹配规则:zuul.routes.serviceId-1.path=/serviceId-1/**表示路径中匹配了serviceId-1/的请求
4.2指定转发的目标URL:zuul.routes.serviceId-1.url=http://域名:端口/表示将匹配了serviceId-1的请求转发到http://域名:端口/处处理
4.3匹配规则和url是成对的,它们的主键都是serviceId-1,而serviceId-1是每个微服务的服务ID或可以辨识这个微服务的标识符
如果微服务有集群,此时需要对上述配置对稍作调整,需要指定某个serviceId下的集群实例列表
4.1指定转发的匹配规则:zuul.routes.serviceId-1.path=/serviceId-1/**
4.2指定转发的目标此时不是直接用url了,而是要指定serviceId,因为serviceId可以对应多个url集群:zuul.routes.serviceId-1.service-id=serviceId-1
4.3指定serviceId-1对应的集群实例的url列表:serviceId-1.ribbon.listOfServers=http://域名1:端口1/,http://域名2:端口2/,.......有多少集群实例,就写多少对应的url(很显然这种手动方式不符合主流需要)
注意点:
1.网关对不同微服务的转发是以serviceId作为区分标志的,因此每个匹配规则配置对,都是以serviceId作为主键的.有多少微服务,就需要配置多少对这样的配置对
2.serviceId是小写的,因此请求路径上必须使用小写.默认情况下,serviceId是spring.application.name的全小写,因此如果想以应用名作为path名称的话,需要用其小写.
2.如果集成了eureka,则zuul会自动发现服务并自动为每个微服务建立转发规则.就不需要手动配置那么多得配置对了.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。