C#框架设计之浅谈SOA与钝化模式

一. 什么是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。

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

       信息员的业务:


       业务员的业务:


       总经理的业务:


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


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


七.后续

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

        下载源代码

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

        转载请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好消息:基于WCF构建企业级大型分布式SOA架构(中级篇)的源码开放下载了,可以向老师索取或者查看最后一个课时下载 下载即可获得如下大礼包:企业级大型分布式SOA框架源码 + 模板网站实践项目源码 + 框架工具、资料 + 初级篇全套源码、视频 学.Net WCF——当架构师 轻松就业 前途无限 掌握高端技术、迈进高收入行列 .Net都是谁在用?——微软、腾讯、网易、戴尔、当当网、携程、招商银行、中国知网、申通快递、房天下、汽车之家等。微软在软件行业的龙头老大位置没有任何人能够否认,它总是站在开发技术的前沿。如今微软正高举.NET大旗继续向前,他正努力使开发变得更加轻松。 学习目标  1、让学员熟练掌握WCF的核心概念及相关编程技能,对WCF技术有一个全面的、深入的、系统的了解;  2、让学员对SOA架构设计的思想和方式具有初步的认识, 对后期我们将要学习的SOA架构有一个宏观的了解;  3、让学员通过完整的示例的学习, 能够熟练搭建开发环境, 服务构建,服务配置,服务调试、服务单元测试, Restful服务的编写, 客户端代理的编写、各种应用程序中消费使用服务等;  4、通过项目实战让学员达到1-3年工作经验水平。达到.NET软件工程师,.Net/C#研发工程师、中高级工程师等岗位所需技能; 课程简介 专注15年C#/.Net开发、科研,在多个中大型企业中负责过多个中大型项目的架构设计、开发、实施部署,积累丰富的研发及实践经验,为Net学习者快速掌握.Net企业级开发常用技术及架构,录制本视频课程系列(分为初级篇,中级篇,高级篇三大课程),采用实战项目从0开始一步步讲授如何搭建项目架构及分析各技术的优劣,提供系统/示例完整源码(价值高)及详细上课日志,及时为您解惑答疑,让课程价值无限; 无论您是Java、C++、Python还是其它语言的开发者,都可以学习本系列课程,因为这种架构设计思想和方式对任何语言来说是一样的,只是实现的技术、语言不一样而已;纯干货,含金量高,价格实惠,物超所值 ,配套的项目架构源码等均能直接应用于实际项目开发中;        课程特色        1:课程设计循序渐进,讲解细致,通俗易懂,由浅入深, 非常适合自主学习;        2:以PPT为大纲,教学过程示例丰富,强调技术关键点,并且分析透彻;先概念后示例再应用实践;        3:物美价廉,本着知识共享,帮助更多有需求者原则,毫无保留,此外,提供源代码/示例代码+课程资料+课程相关工具; 本课程示例程序解决方案 SOA架构部署图(中级篇) SOA架构特色(中级篇) SOA架构解决方案(中级篇) 与SOA架构配合开发的Web实战项目解决方案(中级篇) 教学理念        1:把需要工作的人变成工作需要的人;        2:创设立足学员,突出项目,强化技术,提高能力的教学局面; 注意 1.开发环境VS2015、Eclipse、Sql Server 2008R2; 2.赠送配套资料:详细注释的示例项目源码、详实的讲义等; 3.由初级篇—中级篇—高级篇,建议按顺序一节节学习,一节节理解;从而快速实现架构师之梦;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值