重磅消息:Dromara团队正式开源高性能异步API网关-Soul
声明:本文转载自https://my.oschina.net/shuaiqiyu/blog/2885658,转载目的在于传递更多信息,仅供学习交流之用。如有侵权行为,请联系我,我会及时删除。
微服务为什么需要网关?
Soul是什么? soul 是一款高性能,响应式的网关。我在参考Kong 的插件设计思想,高性能的webflux后,开发而来。
Soul架构设计

执行流程图

Soul功能:
-
支持各种语言,无缝集成Dubbo,SpringCloud,以及http服务。
-
丰富的插件支持,监控,鉴权,限流,熔断,代理,防火墙等等。
-
网关多种规则动态配置,支持各种策略配置。
-
插件热插拔,易扩展。
-
支持集群部署,支持A/B Test。
-
当然也有很多其他的功能,就不一一说了。
Soul 最大的亮点? 插件的热插拔,规则的动态配置。举个列子,比如一个接口你限流是1秒50次,但是你想调小点,像Springcloud-gateway 或者zuul 是不是还得改动配置 然后重启。 soul则不需要,直接在soul-admin找到对应的接口修改即可.
-
soul提供了比较丰富的插件功能,插件与插件规则,选择器,用户可以自由定义 不想用就停用或者删除就行。想用就开启或者新增。
-
soul 是基于webflux的, 依赖rxJava ,其实高性能的,响应式的网关。
-
soul 提供了dubbo ,springcloud rpc框架的支持。
Soul适合人群 是适合所有的微服务系统。
-
后端是java,使用了一些rpc框架(dubbo,springcloud), 然后前端或者其他系统是 .net php 然后需要对接? 然后你问java 后端开发者,dubbo接口怎么调用? java 狗肯定不愿意给你提供http接口,或者直接回一句,你去找领导吧? 这个时候,你只需要告诉它,使用soul,你后端代码一句都不要动,只需要告诉我你zookeeper的地址就好!
-
当然也适合一些其他语言的系统,或者是老系统。 只要你是http服务就行,soul会进行代理请求调用。
Soul性能
- soul 天然支持集群部署,底层采用webflux。
- soul 所有的配置走的都是本地缓存。
- 双11,我们的高峰单台QPS 1W左右。
Soul VS java体系的Zuul,springcloud-gateway
- 性能上来说,soul和sc-gateway 都采用webflux,性能相当
- sc-gateway 或者zuul 基于配置的,接口很多很难集成,而且配置规则不是动态化的。
- soul是插件化的思想,插件热插拔,配置灵活并且是动态化的。
- soul还可以用来排除问题,A/B test。
- soul提供了监控插件来统计qps等等信息。
- soul提供了waf,sign插件,来阻止外来攻击
soul vs kong
- kong 也是非常优秀的框架,但是其实lua语言,开发维护成本高,但是soul完全是java,所以javaer你懂的。
篇幅原因,此文只是一个简单介绍,Soul有很大的价值,喜欢的朋友可以去官网详细介绍。也欢迎大家进行star 和fork
抱拳了,老铁!
本文发表于2018年11月21日 19:00
(c)注:本文转载自https://my.oschina.net/shuaiqiyu/blog/2885658,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如有侵权行为,请联系我们,我们会及时删除.
阅读 10147 讨论 0 喜欢 7