花5分钟时间来了解一下高性能网关Kong会有意外收获

前言

前几天开源发布了 Kong.Net 项目,收到了大量园友的反馈,开源当天就突破了 100 个star ,可喜可贺,但是从侧面也说明,我们 .NetCore 阵营真的非常需要拥抱开源,应该敞开心扉,集众家之长,为我所用,针对有些朋友还不太了解 Kong 的使用方法,本文作一些简单的介绍。

项目地址:https://github.com/lianggx/Kong.Net 请为我们点击 star 加??

声明

本文准备介绍市面上的一些常见的网关,不吹不黑,实事求是,理性讨论,从我做起。

微服务网关

下图直观的为我们展示了Kong网关在微服务中的作用

还可以和 kubernetes 进行无缝集成

(来源:https://konghq.com/solutions/kubernetes-ingress/)

上图是Kong和K8s相结合的结构图,通过Kong网关,可以使业务系统的集成工作变得更加高效且易于管理。

升级位服务网格等部署方案

除了上面的应用场景,Kong 还带来了下面的服务网格等各种部署方案,任君选择,童叟无欺!

(来源:https://konghq.com/solutions/kubernetes-ingress/)

为什么选择了 Kong

1. Spring系列

其实在选择 Kong 之前,我也曾尝试了其它的网关,运维级别的比如Nginx咱就不提了,单就 Spring-cloud Gateway 几乎可以一招吃遍天下,况且还有阿里这个大厂做护法,Nacos/Dubbo 这种实验室+超高流量的实践后开源,那也是极其可怕的,唯一的不好就是除了Java外其它语言没什么机会与之结合,非用不可也不是不行,但是就是非常麻烦,中小企业可以通过上云的方案使用云原生,但是对于自建机房、自建网关和服务集群的,或者是不方便上云的企业来说,只能选择Java。

2. 自带网关

.NetCore 在网关方面也不是没有建树,Ocelot 的star也不少了,但是对于成功的商业应用案例来说,缺少一个有力的推广人,特别是对于http请求的转发,其基于HttpClient的特性,使得在大并发的情况下,反应非常迟钝,一句话:底层太重。不能轻装上阵,就好像转换到Linux后,总是在某些方面有点水土不服。

3. 最终选择

博客园也有大量关于Ocelot对于其它网关的性能对比,这里我就不再一一列出了,大家有兴趣可以在站内搜索一下关键字Ocelot。我在Ocelot的github项目上仔细的查看了每一条issue,并且拿这些issue的回答时间和Kong的issue回答作对比,发现Kong的issue问题响应时间大大快于Ocelot,这可能是因为Kong的贡献值高达200多人的原因

Kong的高效得益于lua和高水平的贡献者,该语言是nginx的开发语言,nginx的高效众所周知,Kong通过Kong Igress Controller和K8s完美结合

为什么需要Kong.Net客户端

还有朋友反馈,既然Kong网关如此完善,RESTFul API 如此高效,为什么还需要Kong.Net客户端呢?这个问题提的非常好!

1. 营销故事
沃尔玛曾经有一个经典的营销案例,说的是啤酒和尿片的故事,说营销人员通过调查,,发现许多男人在下班后都会到超市买给孩子买尿片,他们就想到,如果在尿片旁边摆上啤酒,这些男人会不会同时将啤酒丢人购物车中呢,通过一段时间的观察,超市里的啤酒销量大幅提升。从这个故事中我们发现,便利性和易用性是多么的重要,如果尿片和啤酒在分别堆放在两个不同的货架上,那么如果一个买尿片的男人很大概率不会想起来买啤酒,或者说绕很远的距离去购买啤酒。

从这个场景中我们看到,便利性是多么的重要!

2. 为了快速接入

通过Kong.Net,一个从未接触过Kong网关的人就是可以通过几行代码完成接入,他不需要去理解RESTFul API的接口文档,不用担心传错参数,不用关心是否在配置过程中是否由于某个配置错误引起不明BUG,这些都是极大的提升开发效率的行为,特别是进一步,通过社区的力量,我们可以一起完善这个SDK,使之越来越高效,BUG越来越少,接入越来越快,这就是开源的力量!

Kong 的安装部署

Kong网关的安装部署非常简单,有两种部署方式,rpm 和 docker ,建议 docker方式部署,因为实在是太方便了,只需要复制官网的几个命令,相信我,你不用一分钟就可以部署起来,这里我就不再搬运官方的 docker 安装部署教程了,大家可以参考下面的链接,主要怕官网有更新的话,我这搬运有可能就过时了

https://docs.konghq.com/install/docker/?_ga=2.264012361.438943297.1562658881-406131744.1553753787

Kong Dashboard 控制台

Kong 网关的 Dashboard 目前有两个毕竟大的开源的Dashboard,分别是

// pgbi/kong
https://github.com/PGBI/kong-dashboard/commits/3.0

// pantsel/konga
https://github.com/pantsel/konga

从维护更新的频率来看,pgbi/kong 在走下坡路,而konga维护良好,建议大家使用konga,他们俩的操作界面大同小异,比如我目前使用的是Konga

安装方式推荐:docker

Kong 插件

Kong的插件基于lua编写,内置插件非常丰富,支持验证、安全、流量控制、监控和统计、日志等等,甚至支持自定义插件,你也可以编写自己的插件加入到Kong网关中

就拿流量控制来说,其控制粒度可以具体某个Target,也可以应用到Global,非常灵活。

Kong 响应

在使用Kong进行转发后,Kong会向客户端写入一个默认的头信息

除了默认的头信息,你也可以在Kong服务配置中向客户端写入自定义的响应头信息,非常方便。

健康检查

Kong的健康检查机制非常有意思,分为主动式检查和被动式检查两种,而且两种健康检查方式的配置基本相同,主动检查会修改客户端的状态,将不健康的客户端移除,将恢复健康后的客户端主动加入服务集群,而被动式检查则正好相反;特别有意思的是,其健康检查的路径为根目录“/”,当然也支持定义路径,最重要的是可以自定义httpstatus代码,比如你可以定义4.3、404为健康状态,也可以定义 200、302等一切httpstatus代码。

结束语

优秀的开源产品值得我们深入了解,并结合.NetCore实际使用,这会让.NetCore的生态越来越完善,让社区更强大。
项目地址:https://github.com/lianggx/Kong.Net 请为我们点击 star 加??

原文地址:https://www.cnblogs.com/viter/p/11172469.html

时间: 2024-11-12 20:11:40

花5分钟时间来了解一下高性能网关Kong会有意外收获的相关文章

工作兼职流程及工资结算介绍请花5分钟时间了解!

欢迎您加入2014第一诚信兼职网(我们承接的是全球各大刷信誉平台任务)任务随机发配! 兼职人员工作流程以及常见问题,请认真看完! 郑重声明: 凡是收取任何押金,向你索要账号密码的类似项目,都是骗人的!虽然我们对业务员的要求比较高,但加入本项目我们绝不收取任何押金,更不会向你索要任何密码. 据统计,每天有5万人在网上开店,网店数量已经突破百万大关!一个没有信誉的网店,生意绝对不可能好起来!所以越来越多的卖家开始刷信誉,这也就催生网店刷钻手这个行业.网店刷钻手的任务就是给卖家店铺刷信誉赚钱! ———

工作兼职流程及工资结算介绍请花5分钟时间了解!

欢迎您加入2014第一诚信兼职网(我们承接的是全球各大刷信誉平台任务)任务随机发配! 兼职人员工作流程以及常见问题,请认真看完! 郑重声明: 凡是收取任何押金,向你索要账号密码的类似项目,都是骗人的!虽然我们对业务员的要求比较高,但加入本项目我们绝不收取任何押金,更不会向你索要任何密码. 据统计,每天有5万人在网上开店,网店数量已经突破百万大关!一个没有信誉的网店,生意绝对不可能好起来!所以越来越多的卖家开始刷信誉,这也就催生网店刷钻手这个行业.网店刷钻手的任务就是给卖家店铺刷信誉赚钱! ———

[项目实战派]花40分钟写一个-CBIR引擎-代码公开

浏览网页的时候发现一篇不错的文章"用Python和OpenCV创建一个图片搜索引擎的完整指南"http://python.jobbole.com/80860/.作者在浏览自己旅游的照片的时候,发现照片太多了分类不过来,一时技痒写了个分类软件,虽然简单但是有用.关键的是我发现他在原文中使用了半个小时就写出来了. 蛮快的嘛,我想.那么我要用多长时间写出来了,毕竟对于CBIR也是研究过的. 那么立即来做,首先我要找到是图片.我没有那么多旅游图片(汗),但是别人的照片也是可以一样用的.找到了之

花十分钟,让你变成AI产品经理

花十分钟,让你变成AI产品经理 https://www.jianshu.com/p/eba6a1ca98a4 先说一下你阅读本文可以得到什么.你能得到AI的理论知识框架:你能学习到如何成为一个AI产品经理并且了解到AI产品经理如何在工作中发挥作用,以及AI产品经理需要从哪些方面锻炼能力.最重要的是,通过本文,一切都特别快(手打滑稽). PS:目前只针对弱人工智能(我喜欢简称,此处我们简称为"弱智")进行学习. 首先我们必须要掌握的是AI的专业知识框架,然后了解AI的市场情况,最后要明白

[每周翻译]作为一个计算鸡领域相关的学生狗,有毛东西可以让我花10分钟学习然后享受一生的?

原文地址:https://www.quora.com/As-a-computer-science-student-what-can-I-learn-right-now-in-just-10-minutes-that-could-be-useful-for-the-rest-of-my-life 问:作为一个计算鸡领域相关的学生狗,有毛东西可以让我花10分钟学习然后站撸不哭的?我知道这个问题和 What can I learn/know right now in 10 minutes that w

获取当前时间UTC时间的下一个15分钟时间点

ZonedDateTime zdt = ZonedDateTime.now(ZoneOffset.UTC); int now15Minute = zdt.getMinute() / P15MINUTE * P15MINUTE; //instant当前时刻的下一个15分钟时间点 Instant instant = ZonedDateTime .of(zdt.getYear(), zdt.getMonthValue(), zdt.getDayOfMonth(), zdt.getHour(), now

花10天时间用C语言做了个小站

花10天时间用C语言做了个小站 http://tieba.yunxunmi.com/index.html  简称: 云贴吧 不好意思啊,我上周到今天不到10天时间,用纯C语言写了一个小站!想拍砖的就赶紧拿出来拍啊 预计采集1000万贴,欢迎大家狠狠的来拍吧! 云贴吧是一个完全用纯C语言开发的网站,而且是本人独自设计开发完成的.欢迎各位专家批评指正! 整站大小(网页+C ISAPI类库)不到1MB  容量大.速度快.无论什么贴,随便贴吧,就是量大,容量大,肚量大!

花10分钟搞懂开源框架吧 - 【NancyFx.Net】

原文:花10分钟搞懂开源框架吧 - [NancyFx.Net] NancyFx是什么? Nancy是一个轻量级的独立的框架,下面是官网的一些介绍: Nancy 是一个轻量级用于构建基于 HTTP 的 Web 服务,基于 .NET 和 Mono 平台,框架的目标是保持尽可能多的方式,并提供一个super-duper-happy-path所有交互. Nancy 设计用于处理 DELETE, GET, HEAD, OPTIONS, POST, PUT 和 PATCH 等请求方法,并提供简单优雅的 DS

不会用Word?那不妨花3分钟看看这些Word技巧吧!个个都很好用哦

刚刚毕业,不会用Word?或者对Word不太熟悉,无法完成更高级的操作?那么不妨花3分钟看看下面这些Word技巧吧!它们个个都很好用哦~ 一.基础技巧 1.输入分数 大家知道怎么在Word中输入分数吗?其实很简单,点击菜单栏中的[插入],点击[公式],点击[分数],接着输入相关的数值,即分子.分母即可. 2.插入商标符号 想要在Word中插入商标符号的话,大家可以这样做:点击菜单栏中的[插入],点击[符号],点击[其他符号],选择[Wingdings2],点击[特殊符号],最后选择自己想要的商标