a46d2d85f0e75c8cf4d98aa0fbfee08d4610d6ba
A Managerment API Gateway in Java . Fizz Gateway 是一个基于 Java开发的微服务网关,能够实现热服务编排、自动授权选择、线上服务脚本编码、在线测试、高性能路由、API审核管理等目的,拥有强大的自定义插件系统可以自行扩展,并且提供友好的图形化配置界面,能够快速帮助企业进行API服务治理、减少中间层胶水代码以及降低编码投入、提高 API 服务的稳定性和安全性。
Fizz的设计
产品特性
- 集群管理:Fizz网关节点是无状态的,配置信息自动同步,支持节点水平拓展和多集群部署。
- 服务编排:支持热服务编排能力,支持前后端编码,随时随地更新API。
- 负载均衡:支持round-robin负载均衡。
- 服务发现:支持从Eureka注册中心发现后端服务器。
- 配置中心:支持接入apollo配置中心。
- HTTP反向代理:隐藏真实后端服务,支持 Rest API反向代理。
- 访问策略:支持不同策略访问不同的API、配置不同的鉴权等。
- IP黑白名单:支持配置IP黑白名单。
- 自定义插件:强大的插件机制支持自由扩展。
- 可扩展:简单易用的插件机制方便扩展功能。
- 高性能:性能在众多网关之中表现优异。
- 版本控制:支持操作的发布和多次回滚。
- 管理后台:通过管理后台界面对网关集群进行各项配置。
部署说明
安装依赖的软件
安装以下依赖软件:
- Redis 2.8或以上版本
- MySQL 5.7或以上版本
- Apollo配置中心 (可选)
- Eureka服务注册中心
安装Fizz
- 管理后台
从release目录下载 fizz-manager-professional 和 fizz-admin-professional 的安装包,根据包里的readme进行安装。
- fizz-gateway-community社区版
说明:如果使用apollo配置中心,可把application.yml文件内容迁到配置中心(apollo上应用名为:fizz-gateway);使用不使用apollo可去掉下面启动命令里的apollo参数。
脚本启动:
- 下载fizz-gateway-community的最新代码,使用maven构建好并把构建好的fizz-gateway-community-1.0.0.jar和boot.sh放同一目录
- 修改boot.sh脚本的apollo连接,JVM内存配置
- 执行
./boot.sh start命令启动服务,支持 start/stop/restart/status命令
IDE启动:
- 本地clone仓库上的最新代码
- 将项目fizz-gateway导入IDE
- 导入完成后设置项目启动配置,在VM选项中加入
-Denv=dev -Dapollo.meta=http://localhost:66(Apollo配置中心地址)
jar启动:
- 本地clone仓库上的最新代码
- 在项目根目录fizz-gateway-community下执行Maven命令
mvn clean package -DskipTests=true打包 - 进入target目录,使用命令
java -jar -Denv=DEV -Dapollo.meta=http://localhost:66 fizz-gateway-community-1.0.0.jar启动服务
授权说明
-
网关核心项目fizz-gateway-community社区版本以GNU v3的方式进行的开放,可以免费使用。
-
管理后台项目(fizz-manager-professional和fizz-admin-professional)作为商业版本仅开放二进制包的免费下载,而商业项目请联系我们(524423586@qq.com)进行授权。
Description
Languages
Java
98.2%
JavaScript
1%
Shell
0.6%
Batchfile
0.2%
