一. 什么是SOA

SOA即为Service-Oriented Architecture缩写,翻译过来也就是面向服务的软件架构。通过将软件功能或者是业务流程进行服务化发布,从而达到一种面向于契约和服务,独立于使用平台的效果。而这种效果是跨平台,跨语言的。

如果要简述SOA,那么就必须去简述一下SOA的发展历史。如同设计模式每一个模式书写的那样,SOA的出现必然有其意图和”模式是做什么的”这两方面的内容。那么让我先来简述一下SOA出现的原因。

二. SOA的意图

SOA的出现主要是为了解决如下两个问题:

(1)程序模块或者是软件之间调用关系杂乱,导致摸个地方要进行修改,对于其他的调用方来说,也要进行一些反复的配置或者修改。通过隔离各个软件之间的关系,统一进行调用接口的管理(如下图1),改变杂乱的调用关系。

图1

(2)随着企业软件的日益发展,单模块已经不能满足发展的需要,从而重构形成了多模块的整体架构,这一步通常会使各个模块之间的调用更加的明确,也会使重复功能更加的少,使软件的模块代码功能更加的明确。于此同时对于各个模块所控制的数据库部分,也会进行相应的水平分库或者是进行垂直分表,来满足日益提高的业务需求。如果这样“模块化”之后,还是不能满足需求,那么就需要将一个软件的各个功能在进行相应的细化拆分。使得软件的各个功能从原来的模块化,变成为服务化。这样软件的功能可以分布在不同的服务器上,而不需要将一个软件的所有功能发布在同一个服务器上(如下图2)。

图2

三. SOA的实现

SOA的实现有很多种,例如:webservice、web api等等,我们比较常用的服务发布http接口,通过post json来进行交互。

上述的实现都是即时交互的,即我调用服务走一个业务流程的时候,我每一个服务之间的调用会是瞬时的。也就是说我不会去等一个http请求,等上几个小时,这明显是不合理的,当然软件自身也会有超时处理。那么如果真的存在一个业务,会使得一个流程的处理长达几小时或者业务的处理过程中需要人工审核停顿,那么上述的实现方式可能不在适用。

那么如何处理这种服务流程的调用呢?下面我就要来说说SOA的钝化模式。

四. 钝化模式的意图

这里我沿延用王清培前辈写的《.net框架与设计》书中的原话来说明该模式的意图(当然大家有兴趣也可以看一下该书中有关钝化模式的讲解),书中写道如图3内容

图3

不难看出钝化模式就是用来解决一个业务在不同流程中的持久化问题的。这里还是要强调一下持久化,所谓持久化就是将文件或者数据保存在一个可以持久保存的介质上的行为。钝化模式通过将程序进行冻结处理后,放在一个持久化介质上,等待到他需要再次进行执行处理的时候,在将其进行恢复执行状态,继续执行。可能说到这里大家一头雾水。什么?程序还可以跑一半,隔一段时间之后,恢复一点继续跑的吗?恩,确实通过钝化模式可以做到。我们来看看代码。

五. 模拟的业务场景

在摆出代码之前,我还是想先介绍一下这个代码模拟的业务场景,以便于理解。

某公司是一个罐头制造厂商,生产各种罐头,包括我最喜爱的黄桃罐头和我最不喜欢的鲱鱼罐头。这个批发商生意很好,有很多很多的客户下订单,但是一个审核流程需要信息员确认客户信息、业务员审核客户购买商品数量和总经理在最终审核之后在该笔订单上签字确认。但是这个审核流程由于业务繁多,或者总经理比较繁忙,无法再每次客户下单的时候,立即对业务进行处理,也无法在每一个角色完成之后,下一个角色立即进行处理。于是改制造厂商通过钝化模式,开发了一个用来处理他们业务流程的软件。业务流程如以下图4所示。

图4

六. 程序实现

先大致的说一下各个类实现的功能。下面的是vs生成的类图,如下图5:

1.  PassivationStatus枚举:这个枚举是用来标示流程究竟走到了哪一个流程,类似于一个描点。通过从PassivationManger(流程控制器,以下该类均称为流程控制器)中获取对应的存放着当前流程的属性CurrentStatus来确定流程究竟走到了那里;

2.  PassivationManger类:这个类是钝化模式的核心。他维护了一个用来绑定信息员、业务员和总经理三个方法的委托实体。他同时也维护了一个流程审核过程每一个过程转移到下一个过程的状态链(flowList)。通过使用AddFlow来增加业务和业务状态,通过RunFlows来对业务流程链进行执行。其中FlowStatusMoveNext是用来当一个流程走完之后,自动将执行状态进行下一的方法,而_currentStatusId是用来记录当前移动在flowList中的索引位置;

3.  PassivationMangerDelegate委托:用来统一信息员、业务员和总经理三个业务方法参数和返回值,以便于注册到流程控制器的业务流程链中。当然这也是统一参数设计思想的体现。

4.  ManagerControl类:主要是用来管理流程控制器的类,用来冻结和还原PassivationManger类。其内部维护一个流程控制器。

实现原理:通过将每个业务方法和业务状态注册到流程控制其中,在每次执行代码的时候将序列化的流程执行状态还远,然后根据当前的流程状态来执行对应状态的流程,在执行完之后对流程状态进行后移,然后将执行的情况进行序列化。

七. 程序运行结果

由于个人不喜欢在book文章中贴一大段一大段的代码,所以就放一下运行的结果吧。具体的代码和相关详细的解释会在工程中给出,个人用的vs版本是2010。

三次运行,运行的结果如下面图所示。

信息员的业务:

业务员的业务:

总经理的业务:

文件序列化后的内容大家如果有兴趣也可以自己分析一下,还有持久化的载体和方式也不止那么一种,大家可以自己去尝试一下。

每次运行之后序列化的文件

七.后续

大家最喜欢的工程文件请点击下方文字下载。

下载源代码

如果对本文有什么意见或者是建议都可以在下面的评论中提出,我之后会多写一些有关于框架的文章。您的支持是我的动力。

转载请注明出处。

C#框架设计之浅谈SOA与钝化模式相关推荐

  1. 框架设计:浅谈ECS设计思想(一)

    从一开始的面向过程编程,再到后来面向对象编程.随着硬件性能的不断改进,用户对软件应用的要求也水涨船高.愈发庞大的应用不再是一个人或几个人的小团队能够完成的呢,分工愈来愈明显,逼迫着编程思想不断进步. ...

  2. 单片机sleep函数的头文件_单片机代码模块化设计思想浅谈

    前言:前段时间分享的文章[单片机裸机代码框架设计思路],很多读者给我留言,觉得很不错,对于初学者而言,这是一个进阶的技巧,对于我而言,这是对自己总结和表达能力的一个提升. 本文章我们再谈谈单片机代码的 ...

  3. 浅谈企业中台商业模式及建设思路

    浅谈企业中台商业模式及建设思路 文章目录 浅谈企业中台商业模式及建设思路 前言 企业中台的定义和能力 企业中台的商业故事 企业中台的商业模式 构建企业中台时不同的企业初衷 企业中台的价值主张 企业中台 ...

  4. python 前端框架比较_浅谈五大Python Web框架

    说到Web Framework,Ruby的世界Rails一统江湖,而Python则是一个百花齐放的世界,各种micro-framework.framework不可胜数,不完全列表见: 虽然另一大脚本语 ...

  5. (浅谈SOA架构)------SOA架构演变由来

    SOA架构演变由来 一:了解市场上系统架构 1.1:市面上有那些架构? (1):单体架构 (2):垂直架构 (3):分布式服务架构 (4):SOA架构 (5):微服务架构 1.2:各自架构的优缺点 1 ...

  6. 用户数据表设计借鉴 浅谈数据库用户表结构设计,第三方登录 基于 Token 的身份验证

    最近对用户数据表的设计比较感兴趣,看到了两篇比较好的文章. 浅谈数据库用户表结构设计,第三方登录 转载于: https://www.cnblogs.com/jiqing9006/p/5937733.h ...

  7. 激活函数设计vhdl_浅谈神经网络中激活函数的设计

    激活函数是神经网络中非线性的来源,因为如果去掉这些函数,那么整个网络就只剩下线性运算,线性运算的复合还是线性运算的,最终的效果只相当于单层的线性模型. 那么,常见的激活函数有哪些呢?或者说,激活函数的 ...

  8. 计算机辅助药物设计 中药,浅谈计算机辅助药物设计在中药研究中的应用(1).pdf...

    文档介绍: · 前沿进展· 浅谈计算机辅助药物设计在中药研究中的应用巴真真, 于巍巍摇摇作者单位: 圆缘远远园猿山东省滨州市,滨州职业学院医疗学院摇摇[摘要]摇计算机辅助药物设计( 悦粤阅阅)的理论和 ...

  9. 计算机辅助药物设计 中药,浅谈计算机辅助药物设计在中药研究中的应用.pdf

    浅谈计算机辅助药物设计在中药研究中的应用.pdf 还剩 1页未读, 继续阅读 下载文档到电脑,马上远离加班熬夜! 亲,喜欢就下载吧,价低环保! 内容要点: 戈HI心脑肺m管病杂志2012年1 JlJ第 ...

最新文章

  1. Nagios—服务和性能监控
  2. 获取用户真实Ip地址
  3. gorm crud简单代码示例
  4. ios7 苹果原生二维码扫描(和微信类似)
  5. python编程入门视频-Python编程入门电子书及视频教程-非常详细『强烈推荐』
  6. 网站防盗链就是那么简单
  7. Qt 2D绘图之一:基本图形绘制和渐变填充
  8. mysql双主配置及其注意事项
  9. TypeScript 中括号用法笔记
  10. Oracle 文字排序,按照拼音,姓氏笔画等
  11. 字符串(String)
  12. Elasticsearch:《大数据集群学习笔记与实战》之es集群(2)es基本操作
  13. 教你怎样激励自己做好每一件事
  14. 图解 pci pci-x pci-e
  15. MP-BGP报文详解
  16. Future、FutureTask、CompletableFuture简介
  17. 手写call,apply,bind函数
  18. PostgreSQL查看表结构语句
  19. 测试职业发展、高级测试需要知道哪些、P6测试需要知道什么、测试的知识点、测试自我提升、测试圣经
  20. 心电设备检测YY1139总结遇到的问题和解决方法

热门文章

  1. 知识共享有多难?做好这几点,问题统统解决
  2. 网上买电信电话卡又被欺骗百元
  3. 金山云VR+8K超高清直播全链路解决方案
  4. 从里面学到的关于过去的经验 前篇
  5. 最新Exsi-6.7.0U3b版本下载
  6. 《偏生要鲜花着景,应这急景流年》
  7. 语音处理/语音识别基础(六)- 语音的端点检测(EPD/VAD)
  8. Mockplus走进四川师范大学
  9. 面试被问:你了解的海康威视是一家怎样的公司?
  10. 暑假的计划【写在这里,监督自己】