Zuul服务网关

本文介绍了Zuul作为微服务网关的作用,包括路由转发和过滤功能。详细阐述了Zuul如何与Eureka整合,实现服务发现,并通过配置示例展示了Zuul如何注册到Eureka并获取服务信息。此外,还讲解了Zuul在Feign调用中的应用,以及自定义Zuul过滤器进行请求拦截和处理。
摘要由CSDN通过智能技术生成

理论知识

1.作用

  • 代理
  • 路由
  • 过滤

2.路由

  • 将外部请求转发到具体微服务实例上
  • 实现外部访问统一入口的基础

3.过滤

  • 干预请求处理过程,实现请求校验服务聚合

4.Zuul与Eureka整合

  • Zuul将自身注册到Eureka
  • Zuul从Eureka获取其他微服务消息
  • 实现微服务的获取都经过Zuul跳转后获取

HelloZuul

1.新建模块microcloud-zuul-9527

在这里插入图片描述

2.pom.xml

<!--/routes返回所有路由规则-->
<!--ribbon+hystrix-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>

<!--zuul需要获取所有服务信息,需要通过eureka客户端访问eureka服务端-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

<!--zuul中依赖actuator,用于监控zuul服务状态-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

3.application.yml

server:
  port: 9527

eureka:
  application:
    name: microcloud-zuul-1
  client:
    service-url:
      defaultZone: http://eureka1:7001/eureka/,http://eureka2:7002/eureka/,http://eureka3:7003/eureka/
    register-with-eureka: true  #注册到eureka
    fetch-registry: true  #获取服务中的注册信息

spring:
  application:
    name: microcloud-zuul

#开启actuator监控端口
management:
  endpoints:
    web:
      exposure:
        include: '*'  #'routes'

#zuul服务路由配置
  #原来的访问路径:http://localhost:9527/microcloud-provider-dept(小写应用名)/provider/findAll(请求路径)
zuul:
  ignored-services: '*' #隐藏所有应用名,不可以直接通过应用名访问,只可通过routes设置的映射访问
  routes: #注册服务到zuul
    microcloud-provider-dept: /provider/**  #应用名:映射地址 -> 访问地址http://localhost:9527/provider(映射)/provider/findAll(请求路径)
    #映射的不同写法
    #dept.path: /provider/** #映射地址
    #dept.serviceId: microcloud-provider-dept #应用名

  prefix: /prefix  #路由前缀 —> 访问地址http://localhost:9527/prefix(路由前缀)/provider(映射)/provider/findAll(请求路径)

4.启动类

  • ZuulAppConfig
@SpringBootApplication
@EnableZuulProxy
public class ZuulAppConfig {
    public static void main(String[] args) {
        SpringApplication.run(ZuulAppConfig.class, args);
    }
}

Zuul的服务在Feign中生成调用

1.HelloHystrix基础之上进行配置,以下只出示改动部分,原理前面有讲过

2.修改microcloud-api

  • 目录结构
    在这里插入图片描述
  • DeptZuulService
//修改Feign应用名为zuul的
@FeignClient(name = "MICROCLOUD-ZUUL", fallbackFactory = DeptZuulServiceFallbackFactory.class)
public interface DeptZuulService {
    @RequestMapping("/prefix/provider/provider/addDept") //映射到服务提供方的地址,注意改成自己配置routes
    public JsonModel addDept(@RequestBody Dept dept);

    @RequestMapping("/prefix/provider/provider/findById/{id}")
    public JsonModel findById(@PathVariable("id") Long id);

    @RequestMapping("/prefix/provider/provider/findAll")
    public JsonModel fingAll();
}
  • DeptZuulServiceFallbackFactory
//feign接口调用的回退处理类
@Component
public class DeptZuulServiceFallbackFactory implements FallbackFactory<DeptZuulService> {
    @Override
    public DeptZuulService create(Throwable throwable) {
        return new DeptZuulService() {
            @Override
            public JsonModel addDept(Dept dept) {
                JsonModel jsonModel = new JsonModel();
                jsonModel.setCode(-1);
                jsonModel.setData("zuul-消费端端addDept不可用");
                return jsonModel;
            }

            @Override
            public JsonModel findById(Long id) {
                JsonModel jsonModel = new JsonModel();
                jsonModel.setCode(-1);
                jsonModel.setData("zuul-消费端端findById不可用");
                return jsonModel;
            }

            @Override
            public JsonModel fingAll() {
                JsonModel jsonModel = new JsonModel();
                jsonModel.setCode(-1);
                jsonModel.setData("zuul-消费端端fingAll不可用");
                return jsonModel;
            }
        };
    }
}

3.新增microcloud-consumer-dept-zuulfeign-80

  • 只是区分microcloud-consumer-dept-feign-80模块,复制一份,下面只出示改变部分
  • 目录结构
    在这里插入图片描述
  • 改变controller下的DeptConsumerServlet
@RestController
@RequestMapping("/consumer")
public class DeptConsumerServlet {

    /*@Autowired
    private DeptFeignService deptFeignService;*/
    @Autowired
    private DeptZuulService deptZuulService;

    @RequestMapping("/addDept")
    public JsonModel addDept(@RequestBody Dept dept) {
        //return this.deptFeignService.addDept(dept);
        return this.deptZuulService.addDept(dept);
    }

    @RequestMapping("/findById/{id}")
    public JsonModel findById(@PathVariable("id") Long id) {
        //return this.deptFeignService.findById(id);
        return this.deptZuulService.findById(id);
    }

    @RequestMapping("/findAll")
    public JsonModel fingAll() {
        //return this.deptFeignService.fingAll();
        return this.deptZuulService.fingAll();
    }
}
  • 改变启动类扫描的feign包
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
@EnableEurekaClient
@EnableFeignClients("com.yc.zuul")//feign接口所在的包
public class ZuulFeignConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ZuulFeignConsumerApplication.class, args);
    }
}

Zuul过滤器

1.修改microcloud-zuul-9527

在这里插入图片描述

2.application.yml

#zuul服务路由配置
  #原来的访问路径:http://localhost:9527/microcloud-provider-dept(小写应用名)/provider/findAll(请求路径)
zuul:
  ignored-services: '*' #隐藏所有应用名,不可以直接通过应用名访问,只可通过routes设置的映射访问
  routes: #注册服务到zuul
    #microcloud-provider-dept: /provider/**  #应用名:映射地址 -> 访问地址http://localhost:9527/provider(映射)/provider/findAll(请求路径)
    #映射的不同写法
    dept.path: /provider/** #映射地址
    dept.serviceId: microcloud-provider-dept #应用名

  prefix: /prefix  #路由前缀 —> 访问地址http://localhost:9527/prefix(路由前缀)/provider(映射)/provider/findAll(请求路径)

  PreLogFilter:
    pre:
      disable: true #关闭过滤
  sensitive-headers: #保留authorization

3.AuthorizedRequestFilter

@Component
public class AuthorizedRequestFilter extends ZuulFilter {
    @Override //过滤器类型,有pre,routing,post,error四种
    public String filterType() {
        //相当pre
        return FilterConstants.PRE_TYPE;
    }

    @Override //过滤器优先级,数字越小优先级越高
    public int filterOrder() {
        return 0;
    }

    @Override //是否过滤,true表示过滤
    public boolean shouldFilter() {
        return true;
    }

    @Override //自定义过滤逻辑,当shouldFilter返回true时会执行
    public Object run() throws ZuulException {
        //获取当前请求的上下文
        RequestContext currentContext = RequestContext.getCurrentContext();
        //认证原始信息
        String auth = "product:a";
        //加密处理
        byte[] encodeAuth = Base64.getEncoder().encode(auth.getBytes(Charset.forName("US-ASCII")));
        String authHeader = "Basic" + new String(encodeAuth);
        //敏感头 过滤
        currentContext.addOriginResponseHeader("Authorization", authHeader);
        return null;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值