Eureka:扩展ClientFilter实现服务注册自定义过滤

Jersey clientFilter 过滤

eureka-wiki

POM依赖:

<dependency>
    <groupId>com.sun.jersey</groupId>
    <artifactId>jersey-client</artifactId>
    <version>1.19.1</version>
</dependency>

实现抽象类ClientFilter的handle方法

public class IpCilentFilter extends ClientFilter {
    @Override
    public ClientResponse handle(ClientRequest clientRequest) throws ClientHandlerException {
        //响应对象的处理
        ClientResponse response = this.getNext().handle(clientRequest);
        return response;
    }
}

注入clientFilter

 @Bean
public DiscoveryClientOptionalArgs discoveryClientOptionalArgs() {
    DiscoveryClientOptionalArgs discoveryClientOptionalArgs = new DiscoveryClientOptionalArgs();
    discoveryClientOptionalArgs.setAdditionalFilters(Collections.singletonList(new IpCilentFilter()));
    return discoveryClientOptionalArgs;
}

自定义filter过滤

@Bean
public FilterRegistrationBean filterRegistrationBean() {
    FilterRegistrationBean registration = new FilterRegistrationBean(new ServerRequestAuthFilter());
    registration.addUrlPatterns("/*");
    return registration;
}

public class ServerRequestAuthFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response,
                         FilterChain filterChain) throws IOException, ServletException {
        //业务实现,根据请求的IP或者参数判断是否可以执行注册或者访问
        filterChain.doFilter(request, response);
    }
}

拦截具体客户端注册、续约、下线请求,请参考 /eureka/apps

com.netflix.eureka.resources.ApplicationResource

总结:

eureka:
  client:
    fetch-registry: true
  1. 跟了下源码,第一种clientFilter只支持懒加载模式(版本1.6.2)
  2. 自定义filter过滤比clientFilter 更加灵活,因为clientfilter不会限制在eureka-server上的任何东西
  3. 源码可以参考:https://gitee.com/log4j/pig

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏码匠的流水账

jvm排查工具箱jvm-tools

本文主要介绍的是一款jvm排查工具箱:jvm-tools。除了对基本jvm封装外,还提供了jmx访问以及火焰图的生成。

1111
来自专栏逸鹏说道

我这么玩Web Api(一)

帮助页面或用户手册(Microsoft and Swashbuckle Help Page) 前言   你需要为客户编写Api调用手册?你需要测试你的Api接口...

3105
来自专栏Kubernetes

Linux kernel Namespace源码分析

学习一下linux kernel namespace的代码还是很有必要的,让你对docker容器的namespace隔离有更深的认识。我的源码分析,是基于Lin...

9548
来自专栏JMCui

Netty 系列八(基于 WebSocket 的简单聊天室).

    之前写过一篇 Spring 集成 WebSocket 协议的文章 —— Spring消息之WebSocket ,所以对于 WebSocket 协议的介绍...

2805
来自专栏运维

安装rhel6系统分区指导

系统分区指导 1,Unless you have a reason for doing otherwise, we recommend that you cr...

1523
来自专栏郭霖

巧用Android网络通信技术,在网络上直接传输对象

要做一个优秀的Android应用,使用到网络通信技术是必不可少的,很难想象一款没有网络交互的软件最终能发展得多成功。那么我们来看一下,一般Android应用程序...

2256
来自专栏deepcc

linux中nodejs后台运行工具forever

3118
来自专栏ImportSource

针对事件驱动架构的Spring Cloud Stream

今天我们要分享一个比较有意思的内容。就是如何通过spring cloud 的stream来改造一个微服务下事件驱动的框架。 为什么要改造?我们都知道事件驱动的微...

4558
来自专栏小樱的经验随笔

自己手动复现一个熊猫烧香病毒

最近逛了一下 bilibili ,偶然的一次机会,我在 bilibili 上看到了某个 up 主分享了一个他自己仿照熊猫病毒的原型制作的一个病毒的演示视频,虽然...

6352
来自专栏WindCoder

SpringBoot邂逅Shiro-前后端分离时的配置

本篇仅是记录集成的基础过程,至于shiro框架的基础概念和使用细节,可以自行查阅相关资料,本文不做讨论。

4.5K2

扫码关注云+社区

领取腾讯云代金券