路由 和 过滤 两个功能 路由功能: 负责将外部的请求转发到具体的微服务实例上,是实现外部访问统一的基础。和(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为前缀进行访问
复制代码
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:走起来!!!