一、前言

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组件,在引擎中又有什么作用呢?

5. Stage(关卡)组件介绍

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

二、功能使用

 1.swagger与stage同时使用

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

设置jwt 鉴权

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

 2.服务聚合和中转服务

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

注:

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

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

3. 文件服务

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

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

然后可以通过swagger 进行测试

上传文件

下载文件

4. SSL认证

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

5. 网关

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

三、性能

测试环境

CPU:Intel Core i7-4710MQ

内存:16G

硬盘:1T SSD+512G HDD

网络:局域网

版本:.net core 2.2

四、总结

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

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


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

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

  1. 基于微服务架构的分布式系统:如何设计和实现高效的微服务系统

    文章目录 基于微服务架构的分布式系统:如何设计和实现高效的微服务系统 1. 引言 1.1. 背景介绍 1.2. 文章目的 1.3. 目标受众 2. 技术原理及概念 2.1. 基本概念解释 2.2. 技 ...

  2. 阿里云MVP:如何设计实现一个通用的微服务架构?

    最近有看到"微服务,分久必合.合久必分"的言论,我同意,微服务不是架构演变的终点,细说还有Serverless.FaaS等方向.但纠结要不要拆分是没有必要的,拆往往是随着业务变化不 ...

  3. 互联网架构设计漫谈 (4)-你知道微服务的“分与合”

    互联网架构设计漫谈 (4)-你知道微服务的"分与合" 业务高速发展的今天,单应用已经无法支撑庞大/复杂的业务系统.所以需要根据业务进行拆分,方便业务做扩容,并且增加大系统的团队协作 ...

  4. 如何设计一个复杂的业务系统?从对领域设计、云原生、微服务、中台的理解开始...

    欢迎关注方志朋的博客,回复"666"获面试宝典 01 如何解决复杂业务设计 Aliware 软件架构设计本身就是一个复杂的事情,但其实业界已有一个共识,那就是"通过组件化 ...

  5. 微服务设计指导-使用云原生微服务解决传统海量跑批时引起的系统间“级联雪崩”以及效率

    问题描述 这也是一起真实的生产事故,如下图所示 这种"雪崩"是属于企业内部系统雪崩. 我们都知道如果是在外部http (包括一切restful.soap请求.http类型调用)调用 ...

  6. 微服务平台的设计要点_我在微服务方面的经验中有5点要点

    微服务平台的设计要点 I am a big fan of microservices. And at the same time, I am not always so fond of them. S ...

  7. 谈谈SOA架构和微服务,以及两者的区别区别

    众所周知,任何架构都是一步步演变而来的.没有最好的架构,只有最合适的架构. 先来看看第一代单体应用,我想这个大家也是很熟悉.大部分人入门也是从单体应用开始的. 第一代单体应用架构 这里放一个图,图中可 ...

  8. 《微服务设计》(一)---- 微服务

    如果系统没有很好地解耦,那么一旦出现问题,所有的功能将不可用.友一个黄金法则是:你是否能够修改一个服务并对其进行部署,而不影响其他任何服务. 微服务好处 技术异构性.在一个由多个服务相互协作的系统中, ...

  9. 3.从零开始搭建基于SpringCloud的京东整站_文件上传微服务

    本次目标 本次实现的目标:实现图片上传微服务. 文件上传在很多项目和很多模块都要用到,所以将其单独作为一个微服务. 如下图蓝色箭头所示:FileUploadMicroservice 静态资源 本案例图 ...

最新文章

  1. physx选择显卡还是cpu_工控机如何选购cpu,工控机cpu选择盒装好还是散装好
  2. linux乌班图vi怎么使用,Ubuntu上vi(vim)编辑器使用教程
  3. ldap统一用户认证php,针对LDAP服务器进行身份认证
  4. [html] 关于<form>标签的enctype属性你有哪些了解?
  5. python爬虫ssl错误_Python爬虫:Requests的SSLError:certificate verify failed问题解决方案6条...
  6. 【C++】递归打印杨辉三角
  7. 利用计算机系统辅助设计人员,计算机基础知识:计算机辅助设计
  8. 初始化和清理(构造器+重载/重写+this关键字)
  9. 计算机论文物业管理系统,小区物业管理系统的设计与实现(计算机毕业设计)...
  10. 【计算机图形学02】b-spline(b-样条曲线)
  11. 《Inter汇编语言程序设计》8.6 创建多模块程序(ENTERN)
  12. android 横屏转竖屏,(转)Android强制设置横屏或竖屏
  13. winrar主要参数
  14. vivado 2019.2下载地址分享,网盘分享
  15. 重庆大学计算机学院最好老师,“一切都是最好的安排”——蒲俊杰老师喜获重庆大学“最受学生欢迎老师”称号...
  16. Object,byte[],ByteBuffer之间的转换。
  17. 基于OHCI的USB主机 —— UFI数据结构2
  18. 安卓修改gps定位模拟百度地图移动
  19. 学成在线--day04 页面静态化
  20. 自己在网上收集的一些Qt的小用法

热门文章

  1. 谷歌相册_Google相册中的新存档功能是什么?
  2. 在Outlook 2007中查看您的Google日历
  3. 计算机存有多少游戏,8G和16G的计算机内存之间有很大区别吗?玩游戏需要多少内存?...
  4. 首次公开!单日600PB的计算力--阿里巴巴EB级大数据平台的进击
  5. Python_list部分功能介绍
  6. Tomcat定义虚拟主机案例
  7. 【转】为什么自动车完全不可以犯错误
  8. Linux学习笔记之一————什么是Linux及其应用领域
  9. MTD/MT/MDD/MD以及LIB/DLL之间的一些联系和问题
  10. 如何提高电脑办公效能