路由
和 过滤
两个功能 路由功能: 负责将外部的请求转发到具体的微服务实例上,是实现外部访问统一的基础。和(controller功能类似)
过滤器功能: 负责对请求的处理过程进行干预、是实现请求校验、服务聚合等功能的基础。
导入依赖
、 编写配置
、 开启服务
<dependencies> <!--Zuul:服务网关--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Hystrix服务熔断与降级--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Hystrix监控页面--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Feign--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--给消费者引入Ribbon依赖。让消费者从注册中心获取到服务列表的地址--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--给消费者加入Eureka客户端,方便消费者在注册中心发现更多服务--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> <version>1.4.3.RELEASE</version> </dependency> <!--实体类+web--> <dependency> <groupId>com.baoji</groupId> <artifactId>springcloud-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> </project> 复制代码
server: port: 9537 spring: application: name: springcloud-zuul-gateway eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/ instance: instance-id: zuul9537 # 修改eureka上的默认描述信息 prefer-ip-address: true # true 可以显示服务的ip,而不是显示localhost #info信息 info: app.name: zuul-gateway-9537 company.name: com.baoji 复制代码
package com.baoji.springcloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; @SpringBootApplication @EnableZuulProxy //开启Zuul路由网关 public class ZuulApplication_9537 { public static void main(String[] args) { SpringApplication.run(ZuulApplication_9537.class,args); } } 复制代码
此电脑->C盘->windows->system32->drives->etc->hosts
127.0.0.1 www.baoji.zuul.com 复制代码
http://localhost:8001/dept/get/1
,查看服务提供方数据
http://www.baoji.zuul.com:9527/springcloud-provide/dept/get/1
,隐藏真实地址,通过域名和微服务名来访问,可以达到同样的效果 #配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替),zuul的路由功能 zuul: routes: mydept.serviceid: springcloud-provider mydept.path: /mydept/** 复制代码
http://www.baoji.zuul.com:9527/mydept/dept/get/1
访问也能达到同样的效果,这样在地址栏中就不能看见任何关于微服务的信息了 我们需要在application.yml中配置忽略原真实路径访问
zuul.ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了,如果忽略所有服务名,用“*”表示隐藏所有服务名 复制代码
http://www.baoji.zuul.com:9527/baoji/mydept/dept/get/1
zuul.prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码
zuul网关路由路由和过滤功能配置如下:(4代表Zuul路由功能,6和7代表zuul过滤功能)
#配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替) zuul: routes: mydept.serviceid: springcloud-provider mydept.path: /mydept/** ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了 zuul的过滤功能 prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码最后YML:
server: port: 9537 spring: application: name: springcloud-zuul-gateway eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/ instance: instance-id: zuul9537 # 修改eureka上的默认描述信息 prefer-ip-address: true # true 可以显示服务的ip,而不是显示localhost #info信息 info: app.name: zuul-gateway-9537 company.name: com.baoji #配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替) zuul: routes: mydept.serviceid: springcloud-provider mydept.path: /mydept/** ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了 zuul的过滤功能 prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码
好了,我们今天学习了Zuul网关的路由、过滤功能实现,接下来我们学习使用Git远程访问springcloud config配置文件的操作,期待吧!赶快点赞:+1:+关注吧!:two_hearts:小红心:two_hearts:走起来!!!