基于surging 的stage组件设计,谈谈我眼中的微服务

一、前言

surging 开源地址:https://github.com/dotnetcore/surging

随着业务的发展,并发量的增多,业务的复杂度越来越大,对于系统架构能力要求越来越高,这时候微服务的设计思想应运而生,但是对于微服务需要引擎进行驱动,这时候基于.NET CORE 的微服务引擎surging 就诞生了。

 1.那么怎么样去理解微服务呢?

    微服务是针对业务的松耦合,是对于业务的解耦,也是粒度最小的功能业务模块,对于本地和远程的抽象化,对于远程调用提供了服务治理保证了可靠性通信。

2. 那么什么是微服务引擎呢?

  微服务引擎是微服务的容器,是扫描或引用加载业务服务模块驱动生成服务提供者,针对于行业解决方案,集成相应的service host,而针对于业务需要一些中间件来辅助,比如缓存中间件,eventbus中间件(消息中间件),数据储存中间件,而各个服务又可 以互相通过rpc进行可靠性通信。

3. 是不是需要有非微服务不可的心态去重构系统?

  微服务是针对于业务的松耦合,是针对于调用的抽象,所以相关复杂的系统都可以使用微服务的设计思想去重构,但是团队对于微服务把握不到位的话,我建议还是使用SOA去设计系统,后面可以使用k8s做服务治理。

4.那么surging 又能做什么呢?

  • 构建Web应用程序,微服务和api网关

  • 微服务可以部署在docker。可以使用k8s、rancher服务编排弹性扩容

  • 提供了多协议支持

  • 支持负载平衡分流压力

  • 基于.NET Core的跨平台可以在Windows,macOS和Linux上运行;也可以移植到其他操作系统。

  • 简化的服务调用,通过服务规则的指定,就可以做到服务之间的远程调用,无需其它方式的侵入

  • 服务自动注册与发现,不需要配置服务提供方地址,注册中心基于ServiceId 或者RoutePath查询服务提供者的地址和元数据,并且能够平滑添加或删除服务提供者。

  • 软负载均衡及容错机制,通过surging内部负载算法和容错规则的设定,从而达到内部调用的负载和容错

  • 分布式缓存中间件:通过哈希一致性算法来实现负载,并且有健康检查能够平滑的把不健康的服务从列表中删除

  • 事件总线:通过对于事件总线的适配可以实现发布订阅交互模式

  • 容器化持续集成与持续交付 :通过构建一体化Devops平台,实现项目的自动化构建、部署、测试和发布,从而提高生产环境的可靠性、稳定性、弹性和安全性。

  • 业务模块化驱动引擎,通过加载指定业务模块,能够更加灵活、高效的部署不同版本的业务功能模块

针对于以上描述,我们再来看看surging 2.0 新提供的stage组件,在引擎中又有什么作用呢?

  640?wx_fmt=jpeg

5. Stage(关卡)组件介绍

stage 从字面翻译是关卡,阶段。而取名设计的目的是通过这个阶段关卡就能进行下一个阶段的访问。其作用针对于对外访问,其功能有路由转发,鉴权,第三方调用,服务聚合网关,中转服务。

二、功能使用

 1.swagger与stage同时使用

swagger组件可以通过加载的业务接口在线生成API文档,这样可以给开发人员进行测试和调试,那么配合stage组件使用就可以针对鉴权服务进行测试。

设置jwt 鉴权  

640?wx_fmt=png


通过设置HttpPort 或者stage 的HttpsPort和HttpPort,就能通过相关端口访问,默认是280,然后可以通过http://127.0.0.1:280/swagger/index.html就能访问

640?wx_fmt=png

 2.服务聚合和中转服务

 针对于第三方或者移动端调用,需要做服务聚合,以满足业务结果返回的需要, 这个时候就可以使用stage组件了

  注:

  •    聚合服务、中转服务没有服务治理,服务注册与发现

  •    聚合服务、中转服务调用微服务,可以支持服务治理,服务注册与发现,服务缓存降级

3. 文件服务

 通过引用stage 组件,然后设置Policy配置就能跨域进行文件上传和下载功能,而且文件服务可以水平扩展部署

需要按照以下代码进行编码,最主要是注意参数和返回结果类型

640?wx_fmt=png

 然后可以通过swagger 进行测试

上传文件

640?wx_fmt=png

 下载文件

640?wx_fmt=png

4. SSL认证

 可以通过配置HttpsPort、CertificateFileName、CertificateLocation、CertificatePassword来生成ssl认证

5. 网关

 stage 可以生成对外访问网关,其作用是路由转发和鉴权

三、性能

测试环境

CPU:Intel Core i7-4710MQ

内存:16G

硬盘:1T SSD+512G HDD

网络:局域网

版本:.net core 2.2

 640?wx_fmt=png

四、总结

surging 2.0将在下月底进行发布,敬请期待

原文地址:https://www.cnblogs.com/fanliang11/p/11204793.html


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314784.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HDU - 6971 K - I love max and multiply sosdp

传送门 文章目录题意:思路:题意: 思路: 直接求i&j>ki\And j>ki&j>k不是很好求,所以转换成i&jki\And jki&jk的情况。 考虑对a,ba,ba,b求一遍超集,让后从[0,n−1][0,n-1][0,n−1]扫…

推荐10个技术圈优质的公众号大号

公众号有很多但需要什么只有自己知道本次筛选了一批技术圈优质的公众号,主要与python、人工智能、机器学习、技术人生相关希望对你有所帮助!▼★长按二维码,选择“识别二维码”进行关注。▲长按二维码,识别关注简介:Python爱好者社…

使用Kubeadm创建k8s集群之部署规划(三十一)

前言 上一篇我们讲述了使用Kubectl管理k8s集群,那么接下来,我们将使用kubeadm来启动k8s集群。部署k8s集群存在一定的挑战,尤其是部署高可用的k8s集群更是颇为复杂(后续会讲)。因此本教程会在部署的过程中穿插讲…

HDU - 6967 G I love data structure 线段树维护矩阵 + 细节

传送门 文章目录题意:思路:题意: 给你两个长度为nnn的数组a,ba,ba,b,你需要完成如下四种操作: 思路: 思路还是比较简单的,首先建一颗线段树,线段树中维护a,b,a2,b2,aba,b,a^2,b^…

荐读|属性与可直接访问的数据成员之间应该如何选

写在前面在书写C#代码的时候你是否有过这样的经历:经常混用属性以及公有的数据成员。毕竟他们的用法基本一致,对于使用来说好像没什么区别啊。其实我也经常使用类的公有的数据成员来定义一些常量,为了简单,在一些仅仅需要对外暴露…

2021牛客暑期多校训练营3 I Kuriyama Mirai and Exclusive Or 差分 + 二进制分治

传送门 文章目录题意:思路:题意: 给你一个数组aaa,让你实现以下两个操作之后输出数组aaa。 n≤6e5,ai≤230−1n\le6e5,a_i\le2^{30}-1n≤6e5,ai​≤230−1 思路: 下面介绍的思路清奇,反正我想不到。 对…

Lock VS Monitor

介绍介绍对开发人员来说,处理关键代码部分的多线程应用程序是非常重要的。Monitor和lock是c#语言中多线程应用程序中提供线程安全的方法(lock关键字的本质就是对Monitor的封装)。两者都提供了一种机制来确保只有一个线程同时执行代码,以避免代码功能被其…

程序员修神之路--做好分库分表其实很难之二

菜菜哥,上次听你给我讲了分库的情况后,我明白了很多,能再给我讲讲分表吗有收获就好,分表其实有很多情况和分库类似还有不一样的情况吗?有呀,本来数据库和表是不同层面的东西,肯定有差异那你给讲…

2021牛客暑期多校训练营3 B Black and white 最小生成树 + 思维

传送门 文章目录题意:思路:题意: 思路: 对于每个数的位置(i,j)(i,j)(i,j),如果将这个位置染黑,那么我们连一个i−>jni->jni−>jn的边,可以发现我们的操作不影响连通性。如果想要全部染…

关于WinForms的跨显示器DPI自适应

点击上方蓝字关注“汪宇杰博客”导语WinForms 是运行在Windows上的传统.NET桌面应用技术框架。由于历史原因,它对高DPI以及跨不同DPI屏幕的支持有些问题,本文将探索尽可能的解决方案。Windows 的“黑历史”Windows 系统的默认DPI(更确切的说法…

.NET开发框架(九)-NLB网络负载平衡配置实战(视频)

(NLB配置实战教程-有声视频-第二节)请持续关注公众号,第三节(NLBARR)正在录制中~第六章IIS负载均衡教程,至今共有37人参与学习尚未学习第六章-IIS负载均衡-视频教程的童靴,赶紧跟上进度,别掉队了…

C#各版本新增加功能

本系列文章主要整理并介绍 C# 各版本的新增功能。C#8.0 于 2019年4月 随 .NET Framework 4.8 与 Visual Studio 2019 一同发布,但是当前处于预览状态。预计在2019年9月正式发布。目前提供以下功能可供试用:Readonly 成员默认接口成员【*重要,…

宣告推出.NET Core 3.0 Preview 7

译:艾心0626今天,我们宣布推出.NET Core 3.0 Preview 7。我们已经从创建新特性阶段过渡到了完善版本阶段。对于接下来的预览版,我们将把重点放在质量(改进)上。在Windows,macOS和Linux上下载.NET Core 3.0 Preview 7。.NET Core 3…

基于Masstransit实现Eventbus的功能

Masstransit 是一个非常优秀的基于消息进行通信的分布式应用程序框架,详情参考官网。在介绍AA.ServiceBus之前,先介绍下几个概念.分布式分布式系统如何定义?这里引用一下Distributed Systems Concepts and Design(Third Edition)中的一句话&a…

微软解释为什么Rust是系统编程的最佳选择

上周,MSRC(微软安全响应中心)透露出拥抱 Rust 的打算,随后他们将这个话题扩展为一个系列,进一步阐述了使用安全的系统编程语言的的必要性,以及选择 Rust 的原因。在该系列最新一篇文章中,MSRC 团…

你可能不知道的Docker资源限制

本篇内容涉及Docker的内存与CPU限制,可以用于在实际开发中为指定容器设置限制最大使用的资源量,预计阅读时间为5分钟。01—What is 资源限制?默认情况下,容器是没有资源限制的,它会尽可能地使用宿主机能够分配给它的资…

东南亚的IT公司,我劝你善良!

来源公众号:半佛仙人(ID:banfoSB)“真的救我一条‘狗命’,可以吗,谢谢您了,我真的撑不住了。”5月3日,小巴在朋友圈看到这条信息,附着一张长图,定位&#xff…

小白开学Asp.Net Core 《九》

小白开学Asp.Net Core 《九》 — — 前端篇(不务正业)在《小白开学Asp.Net Core 三》中使用了X-admin 2.x 和 Layui将管理后端的界面重新布局了,里面简单的介绍了layui table 的使用以及页面table所需的数据做了简单的封装。今天扩展学习下。…

.net持续集成sonarqube篇之sonarqube安装与基本配置

Sonarqube下载与安装Sonarqube下载地址是:https://www.sonarqube.org/downloads/下载版本有两个,一个是长期支持版,另一个是最新版,此处安装的是最新版,目前版本是7.3,下载的时候点击醒目的蓝色按钮即可(此时下载的是社区版),下面有三个无底色按钮下载链接,分别对应的是开发者版…

Codeforces Round #296 (Div. 1) D. Fuzzy Search FFT匹配字符串

传送门 文章目录题意:思路:题意: n,m,k≤2e5n,m,k\le2e5n,m,k≤2e5 思路: 直接考虑fftfftfft来匹配字符串。 由于kkk是给定的,所以难度低了很多,普通的字符串匹配不能处理这种可以范围相等的情况&#xf…