前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >zuul网关作用_zuul网关的作用

zuul网关作用_zuul网关的作用

作者头像
全栈程序员站长
发布2022-09-22 20:16:50
1.7K0
发布2022-09-22 20:16:50
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

Zuul网关使用步骤

1.在父项目中导入依赖SpringCloud管理

代码语言:javascript
复制
<dependencyManagement>
        <dependencies>
            <dependency>
              <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.SR12</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
</dependencyManagement>

2.在网关微服务中导入Zuul以及Eureka。

说明:注册中心使用Eureka,若使用其他注册中心,则导入对应的注册中心依赖。

代码语言:javascript
复制
<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
</dependencies>

3.在SpringBoot启动类中添加@EnableZuulProxy

4.在ymp文件中配置路由信息

以服务名称为goods示例:

代码语言:javascript
复制
zuul:
  routes:
    goods:
      path: /goods/**
      sensitiveHeaders: Authorization
      url: http://localhost:8081
  prefix: /api
  addProxyHeaders: false

更多配置请阅读官网文档:https://docs.spring.io/spring-cloud-netflix/docs/2.2.9.RELEASE/reference/html/#router-and-filter-zuul

5.在goods微服务添加/hello方法

代码语言:javascript
复制
@RestController
public class GoodsController { 
   
    @GetMapping("/hello")
    public String hello() throws Exception{ 
   
        return "hello world";
    }
}

6.直接调用网关服务

http://网关IP:网关端口/api/hello

网关过滤器使用步骤

1.新建类继承ZuulFilter并实现对应方法。

代码语言:javascript
复制
@Component //必须放入Spring容器
public class AuthorizationFilter extends ZuulFilter { 
   
    @Override
    public String filterType() { 
   
        //过滤器类型,取值:pre、route、post、error
        return "pre";
    }
    @Override
    public int filterOrder() { 
   
        //过滤器执行顺序,越小越优先执行
        return 0;
    }
    @Override
    public boolean shouldFilter() { 
   
        //过滤器执行条件
        return true;
    }
    @Override
    public Object run() throws ZuulException { 
   
        //过滤器执行逻辑
        return "test";
    }
}

2.在SpringBoot启动类加入注解@EnableZuulProxy

深入可阅读:Zuul网关源码解析

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/170630.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Zuul网关使用步骤
    • 1.在父项目中导入依赖SpringCloud管理
      • 2.在网关微服务中导入Zuul以及Eureka。
        • 3.在SpringBoot启动类中添加@EnableZuulProxy
          • 4.在ymp文件中配置路由信息
            • 5.在goods微服务添加/hello方法
              • 6.直接调用网关服务
              • 网关过滤器使用步骤
                • 1.新建类继承ZuulFilter并实现对应方法。
                  • 2.在SpringBoot启动类加入注解@EnableZuulProxy
                  相关产品与服务
                  微服务引擎 TSE
                  微服务引擎(Tencent Cloud Service Engine)提供开箱即用的云上全场景微服务解决方案。支持开源增强的云原生注册配置中心(Zookeeper、Nacos 和 Apollo),北极星网格(腾讯自研并开源的 PolarisMesh)、云原生 API 网关(Kong)以及微服务应用托管的弹性微服务平台。微服务引擎完全兼容开源版本的使用方式,在功能、可用性和可运维性等多个方面进行增强。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档