flying-fish-gateway网关路由服务
flying-fish-gateway(飞鱼网关系统)是基于spring-cloud-gateway开发的网关路由服务,用于服务与服务之间的通讯边界管理,支持过滤器、熔断、鉴权、限流、日志、监控等功能
解决目前项目中A==>B,A==>C,A==>...,服务与服务之间以直链访问的方式,改为A==>gateway==>B\C...,服务走网关访问另一个服务,使得服务通讯可控、可复用、统一管理、安全鉴权、服务能力保护等效果
特色
- 完全支持动态网关路由配置,在控制台界面修改完毕,即可生效
- 支持可动态配置IP、ID、TOKEN过滤器
- 支持可动态配置全局、自定义熔断器,实现业务高峰抗压能力
- 支持可动态配置IP、URL、REQUESTID等基于令牌桶算法自定义限流器,实现业务峰值固化,避免雪崩效应
- 支持可动态配置HEADER、IP、请求参数、时间、Cookie等鉴权验证,加强业务访问安全,避免或减少每个业务服务重复实现安全鉴权规则
软件架构
本工程共分六个模块:
- dynameic-gateway为核心网关路由服务,提供客户端请求转发,服务端地址路由功能,以及过滤器、熔断、鉴权、限流、日志、监控等功能
- dynameic-manage为界面可视化管理后台,提供客户端管理、服务端管理、IP访问管理等功能
- formwork为核心框架,提供基础与公共业务处理模块与类
- eureka-server为注册与发现服务,只需启动即可,无其它业务操作
- admin-server为springboot服务提供监控管理,支持可视化WEBUI,只需启动即可,无其它业务操作
- examples为示例项目
后续开发计划:
- 增加全局日志输出,按一定格式存储,方便后续引入elk做数据分析
- 增加临控功能,支持大厅全局图表展示,与单个服务、单个客户端等访问量、流量、错误等监控图表展示
安装教程
- 依赖spring-boot 2.0.3.RELEASE、spring-cloud Finchley.RELEASE版本,注意版本的搭配
- 需安装eureke、consul等其中任意一种,也可无需注册中心运行
使用说明
- jdk1.8 +
- mysql.5.x +
- redis3.x +
前端项目
- 本项目采用前后端分离,此git仓库为纯后台模块
- 点击此链接下载,前端控制台管理项目 flying-fish-manage
项目界面
评论