上接文章 《一个Golang的Gateway》
在这个文章里提到了准备开源的一个用go语言实现的Gateway,相对的是springcloud里的gateway组件,用go语言开发实现。
springcloud里的gateway可以和配置中心实现gateway的配置,可以和hytrix以及alibaba的Sentinel结合,实现熔断限流的功能,springcloud升级到3.0.1后,摒弃了netfix里的hytrix,使用新的熔断器reslience4j,这几种限流器都未提供比较完善的管理界面进行管理,sentinelboard提供管理工具,但是要做到完全的动态和配置管理,必须添加自己的代码,alibaba开源出来的sentinel的项目,这块的代码目前是没有公开的。而且使用还特别的麻烦。
所以在实现golang的gateway的项目里,首先就像改进这块的功能,不仅要提供gateway的功能,还要有一个比较友好的配置和管理工具。 今天和大家分享的就是这个golang的gateway管理工具先, 这个工具是boot4o-gateway的一个子项目, 完全和boot4go-gateway-server配合,进行boot4go-gateway的配置管理功能。
项目使用fasthttp提供web的http服务,速度上完全比原生的net/http要高出不少。 界面使用CubeUI的组件进行实现。
统计面板
多域名支持,参考nginx的域名功能,这个在springcloud-gateway里是没有的
域名级别的黑名单,黑名单有多层级别的在支持
支持SSL端口的代理,证书动态进行配置
域名下,支持多级路径的匹配和映射
路径映射,强大的路径映射和路径模板转换功能,不仅仅是像spring-gateway的API网关的功能了,完全是一个类似nginx功能的反向代理服务, 在这里还可以配置熔断,限流,私有转发,负载均衡。
对于endpoint的支持,目前是支持的单target组合成的target组, 以后计划准备做ZK,NACOS服务治理的支持
动态测试映射规则
动态测试路径转换, 强大的解析和模板功能,关键性能还很高
SSL证书管理, 支持https
实例管理
Gateway-Manager完全使用Etcd作为配置中心,进行数据配置的保存, 使用EtcD作为Gateway的服务治理的底层, Gateway的服务组件,启动自动注册到etcd治理中心, Gateway-Manager的配置信息,以及Gateway的健康状况完全通过Etcd进行治理和相互通知。
在这个项目中,对etcd用的比较多,在etcd里查询数据,都是通过etcd的命令行进行查询的,非常的不方便, 准备在搞个etcd的UIManager出来。
在这个项目中,把涉及到的一些功能都进行了子项目的划分,
比如etcd的集成,使用的boot4go-etcd。封装了watch,bulkops,license, keepAlive,DistributeLock
比如路径的解析,封装到boot4go-util里,boot4go-util里还封装了有关数组的高级操作, http里封装了有关fasthttp的
比如json的操作,觉得原生的json功能和性能都限制很大,在fastjson的基础上封装了boot4go-fastjson
路径映射这块, 按照springboot里的antPathMatcher的功能,封装了golang的boot4go-Pathmatcher, golang带有原生的Path和FilePath提供Match功能,但是性能和功能实在是有点用的难受, 封装以后,功能和性能都直接杀掉原有的, 而且妥妥的Java语言的味道。
日志这块,当然是boot4go的log4go, 用起来和Logback, Log4j一样, 熟悉的java味道
项目地址:github.com/gohutool/boot4g-gateway