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

随着业务的发展,并发量的增多,业务的复杂度越来越大,对于系统架构能力要求越来越高,这时候微服务的设计思想应运而生,但是对于微服务需要引擎进行驱动,这时候基于.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(关卡)组件介绍

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpyxwf.html