flying-fish-gateway

网关路由服务
授权协议 Apache
开发语言 Java
所属分类 服务器软件、 路由器/防火墙
软件类型 开源软件
地区 国产
投 递 者 百里胜泫
操作系统 跨平台
开源组织
适用人群 未知
 软件概览

flying-fish-gateway(飞鱼网关系统)是基于spring-cloud-gateway开发的网关路由服务,用于服务与服务之间的通讯边界管理,支持过滤器、熔断、鉴权、限流、日志、监控等功能

解决目前项目中A==>B,A==>C,A==>...,服务与服务之间以直链访问的方式,改为A==>gateway==>B\C...,服务走网关访问另一个服务,使得服务通讯可控、可复用、统一管理、安全鉴权、服务能力保护等效果

特色

  1. 完全支持动态网关路由配置,在控制台界面修改完毕,即可生效
  2. 支持可动态配置IP、ID、TOKEN过滤器
  3. 支持可动态配置全局、自定义熔断器,实现业务高峰抗压能力
  4. 支持可动态配置IP、URL、REQUESTID等基于令牌桶算法自定义限流器,实现业务峰值固化,避免雪崩效应
  5. 支持可动态配置HEADER、IP、请求参数、时间、Cookie等鉴权验证,加强业务访问安全,避免或减少每个业务服务重复实现安全鉴权规则

软件架构

本工程共分六个模块:

  1. dynameic-gateway为核心网关路由服务,提供客户端请求转发,服务端地址路由功能,以及过滤器、熔断、鉴权、限流、日志、监控等功能
  2. dynameic-manage为界面可视化管理后台,提供客户端管理、服务端管理、IP访问管理等功能
  3. formwork为核心框架,提供基础与公共业务处理模块与类
  4. eureka-server为注册与发现服务,只需启动即可,无其它业务操作
  5. admin-server为springboot服务提供监控管理,支持可视化WEBUI,只需启动即可,无其它业务操作
  6. examples为示例项目

后续开发计划:

  1. 增加全局日志输出,按一定格式存储,方便后续引入elk做数据分析
  2. 增加临控功能,支持大厅全局图表展示,与单个服务、单个客户端等访问量、流量、错误等监控图表展示

安装教程

  1. 依赖spring-boot 2.0.3.RELEASE、spring-cloud Finchley.RELEASE版本,注意版本的搭配
  2. 需安装eureke、consul等其中任意一种,也可无需注册中心运行

使用说明

  1. jdk1.8 +
  2. mysql.5.x +
  3. redis3.x +

前端项目

  1. 本项目采用前后端分离,此git仓库为纯后台模块
  2. 点击此链接下载,前端控制台管理项目 flying-fish-manage

项目界面

 相关资料
  • : 和 : 根据我找到的一些建议,我尝试从我的eureka服务器中隐藏网关,但问题仍然存在,将其添加到网关中的中:

  • 本文向大家介绍spring cloud gateway网关路由分配代码实例解析,包括了spring cloud gateway网关路由分配代码实例解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了spring cloud gateway网关路由分配代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1, 基于父工程,新建一个

  • 我使用Spring创建微服务。我使用Eureka进行服务发现,使用Zuul进行路由。现在我想切换到Spring Cloud Gateway(因为它的非阻塞特性),但是我没有找到自动路由到每个Eureka服务的方法。 例如,如果一个服务'eureka-client'注册到了Eureka,那么Zuul本身就为这个服务提供了类似于localhost:8762/eureka-client的路径。使用Spr

  • 以下是配置: 当我们公开actuator refreshendpoint并运行actuator/refresh时,路由配置将被重新加载,不会出现任何问题。这里 当我只点击/gateway/refreshendpoint时,它似乎没有做任何事情,但当我点击/actuator/refreshendpoint时,路由会从Spring Cloud Config重新加载到Spring Cloud Gatew

  • Spring Cloud Gateway真的很新--但它“看起来”很容易。有一个问题我很纠结。我的要求是给路径加上前缀,检查一个头变量,查找基于该变量的URI,然后顺着它前进。 问题是uri始终是下面的default_implemension,即使我在idresolvinggatewayfilter中更改了这个值。我怎样才能完成这件事呢?可以随时添加新的ID,这就是“动态”部分。因此,在网关过滤器

  • 我试图将使用工作的网关迁移到Spring Cloud网关,但遇到了请求路由问题。 下面是Spring Cloud Gateway配置的一个片段,我试图在其中配置一个等效的路由: 我使用Spring Cloud Eureka作为我的Discovery服务器(在一个单独的微服务中),并且我目前没有任何配置,如配置DiscoveryClient路由的谓词和过滤器中所述 如果我向发出请求,我将收到一个40