flying-fish-gateway网关路由服务

联合创作 · 2023-10-01 11:24

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

项目界面

浏览 10
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报