SpringCloud 使用Zuul构建微服务网关和服务过滤

SpringCloud 使用Zuul构建微服务网关和服务过滤

在之前项目基础上 新建一个SpringBoot项目(eureka-zuul)

在这里插入图片描述
注意:包名必须和前面一致com.tyq

在这里插入图片描述
勾选依赖

在这里插入图片描述
application.properties配置文件

spring.application.name=eureka-zuul
server.port=8088
eureka.client.serviceUrl.defaultZone=http://localhost:8080/eureka/

zuul.routes.api-student.path=/student/**
zuul.routes.api-student.service-id=eureka-student

zuul.routes.api-grade.path=/grade/**
zuul.routes.api-grade.service-id=eureka-grade

启动类加入注解

@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
public class EurekaZuulApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaZuulApplication.class, args);
    }

}

这时 我们可以根据配置文件端口号 8088 访问student和grade

在这里插入图片描述
访问成功

实现服务过滤

新建一个类filter.MyZuulFilter

package com.tyq.eurekazuul.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

@Component
public class MyZuulFilter extends ZuulFilter {


    private static Logger log = LoggerFactory.getLogger(MyZuulFilter.class);


    @Override
    public String filterType() {
        //路由之前要做的处理
        return "pre";
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;

    }

    @Override
    public Object run() throws ZuulException {
        RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();
        log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));
        Object accessToken = request.getParameter("token");
        if(accessToken == null) {
            log.warn("token is empty");
            ctx.setSendZuulResponse(false);
            ctx.setResponseStatusCode(401);
            try {
                ctx.getResponse().getWriter().write("token is empty");
            }catch (Exception e){}

            return null;
        }
        log.info("ok");
        return null;
    }
}

启动服务

在这里插入图片描述
直接访问会报错

这时我们需要带一个token参数

在这里插入图片描述
完毕!!!!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. Spring Boot是什么?它的主要特点是什么? Spring Boot是一个基于Spring框架的快速开发框架,它可以帮助开发者快速构建Spring应用程序。它的主要特点包括: - 简化配置:Spring Boot可以自动配置大部分常用的配置,开发者只需要少量的配置即可快速搭建应用程序。 - 内嵌服务器:Spring Boot内置了Tomcat、Jetty等服务器,可以直接运行应用程序,无需额外安装服务器。 - 自动化依赖管理:Spring Boot可以自动管理应用程序的依赖,开发者只需要在pom.xml中声明依赖即可,无需手动下载和管理依赖。 - 提供丰富的Starter:Spring Boot提供了大量的Starter,可以快速集成常用的框架和组件,如Spring Data、Spring Security等。 2. Spring Cloud是什么?它的主要组件有哪些? Spring Cloud是一个基于Spring Boot的微服务框架,它提供了一系列的组件和工具,帮助开发者快速构建和部署微服务应用程序。它的主要组件包括: - Eureka:服务注册和发现组件,可以实现服务的自动注册和发现。 - Ribbon:负载均衡组件,可以实现服务的负载均衡。 - Feign:服务调用组件,可以实现服务之间的调用。 - Hystrix:熔断器组件,可以实现服务的熔断和降级。 - Zuul:API网关组件,可以实现请求的路由和过滤。 3. Spring Boot和Spring Cloud有什么区别? Spring Boot是一个快速开发框架,主要用于快速构建Spring应用程序,它提供了自动配置、内嵌服务器、自动化依赖管理等特性,可以帮助开发者快速搭建应用程序。 Spring Cloud是一个微服务框架,主要用于构建和部署微服务应用程序,它提供了服务注册和发现、负载均衡、服务调用、熔断器、API网关等组件和工具,可以帮助开发者快速构建和部署微服务应用程序。 因此,Spring Boot和Spring Cloud是两个不同的框架,它们的目的和应用场景也不同。Spring Boot主要用于快速构建Spring应用程序,而Spring Cloud主要用于构建和部署微服务应用程序。 ### 回答2: Spring Boot和Spring Cloud是目前非常热门的两个Java框架。Spring Boot提供了一种快速构建应用程序的方式,减少了开发人员的配置工作;而Spring Cloud则提供了一系列的工具和服务,使得开发人员能够更加容易地构建分布式应用程序。 为了更好地了解Spring Boot和Spring Cloud,很多公司在面试中都会涉及到相关的问题。以下是一些可能涉及到的Spring Boot和Spring Cloud面试题: 1. Spring Boot和Spring Cloud的关系是什么? Spring Boot是基于Spring Framework的开发框架,它简化了使用Spring Framework构建应用程序的过程。Spring Cloud则是一套基于Spring Boot的工具集,用于构建分布式应用程序。因此,可以说Spring Boot和Spring Cloud是密切相关的。 2. Spring Boot和Spring Cloud的优点是什么? Spring Boot使得开发人员能够更加快速地构建应用程序,减少了繁琐的配置工作。它还提供了自动配置和依赖管理,使得应用程序更加稳定和易于维护。 Spring Cloud则提供了一系列的工具和服务,例如服务注册与发现、负载均衡、断路器、配置中心等,用于构建分布式应用程序。这些工具和服务使得开发人员能够更加容易地构建高可用、可扩展的分布式应用程序。 3. 什么是Spring Boot Starter? Spring Boot Starter是一系列预定义的依赖关系,它可以将一组依赖项收集到一个单一的依赖项中。Spring Boot Starter通常用于快速启动Spring Boot应用程序,默认情况下,您只需包含一个特定的Starter就可以访问所需的所有Spring Boot功能。 4. Spring Cloud中的服务注册和发现是什么? 在分布式应用程序中,服务的注册和发现是一个重要的功能。Spring Cloud提供了Eureka服务,用于服务的注册和发现。当一个服务启动时,它将向Eureka服务器注册自己的信息,并提供一个唯一的标识符。当其他服务需要访问此服务时,它们可以使用此标识符来查找该服务,而不需要知道该服务的物理地址。 5. 什么是断路器? 断路器是一种机制,用于处理分布式系统中的故障。在分布式系统中,如果一个服务失败或超时,那么所有服务都可能因等待响应而不能正常工作。使用断路器可以解决这个问题。当服务出现故障时,断路器将拦截请求,并返回一个备用响应,以确保系统中的其他服务能够正常工作。 总的来说,Spring Boot和Spring Cloud构建分布式应用程序的最佳选择之一。它提供了广泛的功能和工具,可以使开发人员更加轻松地构建高可用、可扩展的应用程序。如果您希望在今后的面试中成功,了解Spring Boot和Spring Cloud的相关知识是必不可少的。 ### 回答3: SpringBoot是一个基于Spring框架的开源Java Web开发框架,它主要是用来简化Spring应用程序的构建过程。而SpringCloud是基于SpringBoot的一个微服务框架,它为分布式系统中的协调、配置管理、服务发现、断路器、路由、微代理等开发模式提供了一系列的解决方案。 在面试中,往往会有与这两个框架相关的问题。以下是一些可能出现的重点问题和答案: 1. SpringBoot有哪些主要特点? SpringBoot的主要特点是简单、快速、功能丰富。它可以帮助开发者在很短的时间内搭建一个基于Spring框架的Web应用,并且内置了很多Spring框架常用的组件和插件,可以使得开发者专注于业务逻辑的开发。 2. SpringCloud的架构包括哪些组件? SpringCloud的组件包括:Eureka、Ribbon、Feign、Hystrix、Zuul、Config Server等。其中,Eureka主要负责服务注册和发现,Ribbon实现服务的负载均衡,Feign是一个声明式REST客户端,Hystrix实现断路器的功能,Zuul实现服务网关的功能,Config Server实现分布式系统的配置管理。 3. SpringBoot如何配置数据库连接池? SpringBoot可以通过在配置文件中设置相应的参数来配置数据库连接池。例如,在application.properties中添加以下配置:spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai,即可将MySQL数据库的连接信息配置到应用程序中。 4. 如何在SpringCloud中实现服务的高可用性? 在SpringCloud中实现服务的高可用性可以通过多个节点的部署和使用Eureka来实现。通过在不同的节点上部署相同的微服务,然后通过Eureka服务注册和发现机制,将这些微服务集群化,并保留一个的负载均衡器,来实现对微服务的高可用性保障。 5. SpringCloud支持哪些服务注册中心? SpringCloud支持Eureka、Consul、Zookeeper等服务注册中心。其中,Eureka是SpringCloud默认采用的一种服务注册中心,它具有高度的可用性和可扩展性,保障了应用系统的高可用性。而Consul和Zookeeper则是另外两种流行的服务注册中心,都具备高度的可用性和系统可扩展性。 总之,SpringBoot和SpringCloud是当下非常流行的Java Web开发和微服务框架,熟悉这两个框架的使用和应用场景,可以为开发者在面试和实际应用中带来很大的帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值