SpringCloud入门(六)之Zuul

导读:本篇文章讲解 SpringCloud入门(六)之Zuul,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

一,概述

Zuul包含了对请求的路由过滤两个最主要的功能:

其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础。而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.

Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。

注意:Zuul服务最终还是会注册进Eureka

代理+路由+过滤三大功能

二,路由基本配置

2.1 pom.xml

新建Module模块servicecloud-zuul-gateway-9527,在pom.xml中加入Zuul坐标:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <parent>
    <groupId>com.lmc</groupId>
    <artifactId>servicecloud</artifactId>
    <version>0.0.1-SNAPSHOT</version>
  </parent>
  <artifactId>servicecloud-zuul-gateway-9527</artifactId>
  
  <dependencies>
  	<!-- 自己定义的api -->
   <dependency>
     <groupId>com.lmc</groupId>
     <artifactId>servicecloud-api</artifactId>
     <version>${project.version}</version>
   </dependency>

   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
   </dependency>

   <!-- 修改后立即生效,热部署 -->
   <dependency>
     <groupId>org.springframework</groupId>
     <artifactId>springloaded</artifactId>
   </dependency>
   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-devtools</artifactId>
   </dependency>
   
   <!-- Zuul相关 -->
   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-eureka</artifactId>
   </dependency>

   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-zuul</artifactId>
   </dependency>

   <!-- Ribbon相关 -->
   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-ribbon</artifactId>
   </dependency>

   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-config</artifactId>
   </dependency>

   <!-- feign相关 -->
   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-feign</artifactId>
   </dependency>
  </dependencies>
</project>

2.2 application.yml

新增application.yml配置文件:

server: 
  port: 9527
 
spring: 
  application:
    name: servicecloud-zuul-gateway
 
eureka: 
  client: 
    service-url: 
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka  
  instance:
    instance-id: gateway-9527.com
    prefer-ip-address: true 

info:
  app.name: lmc-cloud
  company.name: www.lmc.com
  build.artifactId: $project.artifactId$
  build.version: $project.version$

2.3 启动类

创建启动类,增加@EnableZeelProxy注解:

package com.lmc.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableZuulProxy
public class Zuul_9527_StartSpringCloudApp {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		SpringApplication.run(Zuul_9527_StartSpringCloudApp.class, args);
	}

}

2.4 测试

启动:

  1. 启动三个eureka集群
  2. 启动一个服务提供类servicecloud-provider-dept-8001
  3. 启动路由

访问:

  • 不使用路由:http://localhost:8001/dept/get/2
  • 使用路由:http://myzuul.com:9527/servicecloud-dept/dept/get/2

三,路由访问映射处理

3.1 代替服务名

由于在访问路径URL中会暴露服务提供者名称servicecloud-dept,为了保证安全性,我们可以使用代替名称来取代servicecloud-dept访问:

#以前访问
#http://myzuul.com:9527/servicecloud-dept/dept/get/2
 
zuul: 
   routes: 
      mydept.serviceId: servicecloud-dept  #服务ID名称
      mydept.path: /mydept/**  #取代服务ID名称
 
#现在访问
#http://myzuul.com:9527/mydept/dept/get/1

3.2 关闭服务名

但此时原路径的访问依然是成功,要关闭还需再进行配置:

zuul: 
  ignored-services: servicecloud-dept 	#忽略的服务名称
  routes: 
    mydept.serviceId: servicecloud-dept #服务ID名称
    mydept.path: /mydept/**  			#取代服务ID名称

如果要忽略所有服务名称,可使用*代替:

zuul: 
  ignored-services: "*"					#忽略所有服务名称
  routes: 
    mydept.serviceId: servicecloud-dept #服务ID名称
    mydept.path: /mydept/**  			#取代服务ID名称

3.3 使用前缀

如果要对访问使用前缀,要加入prefix配置:

zuul: 
  prefix: /lmc							#统一前缀
  ignored-services: "*"					#忽略所有服务名称
  routes: 
    mydept.serviceId: servicecloud-dept #服务ID名称
    mydept.path: /mydept/**  			#取代服务ID名称
 

所以现在访问就变成了:http://myzuul.com:9527/lmc/mydept/dept/get/1

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由半码博客整理,本文链接:https://www.bmabk.com/index.php/post/81638.html

(0)

相关推荐

半码博客——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!