银弹:构件化与SOA,推进软件“福特模式”生产力

http://www.primeton.com/read.php?id=759&his=1

倪光南:SOA标准与构件技术的结合 http://www.primeton.com/read.php?id=609&his=1

先后加入SCA、SDO国际构件标准组织 普元以面向构件让SOA落地,引领企业 http://www.primeton.com/read.php?id=36

构件化与SOA,推进软件“福特模式”生产力

引子:伴随福特流水线模式的百周年,回顾软件业也已经走了近四十年的光景。而全球软件行业似乎已进入到了中年期,成熟的商业模式,缺乏雨后春笋般的创新型小公司,大公司增长乏力进而带来诸多的并购等。这些都让我们感受到软件行业早已今非昔比,大部分的软件公司都变成了鸡肋。软件从业人员也都从梦想的憧憬回到了实际的运营成本控制中。即使近几年炒得火热的SOA也无法为软件公司带来多少的利润和股价提升。难道软件业真的就这样了,还是在等待新的一次飞跃?

我们小时候都读过这段“生产力的提高会促进生产关系的改变,而生产关系的改变又会反过来促进生产力的发展”,所以我们看待软件业的未来发展还得要从最为本质的提升软件生产力和改变生产关系入手。

构件化通过模块化、层次化和专业化,质变软件生产力

工业化相比较之前的生产方式,给了社会生产力质的提高,而福特的流水线模式正是工业化的代表作。这让我们清晰地看到对于复杂业务的高效处理方式,就是通过层次化设计和模块化分工把复杂的问题分层和模块分解,然后通过‘流水线’协同的方式再层层组合,完成整体的任务。而处于某个层面的被分解的模块,就会有相应领域的专业份子来解决,这个模块又可以再继续递归细分到更小的模块来分解问题。这样某个层面的模块就可以专注于自己所处的相对环境和自身的目标问题。这种模式从本质上改变了模块之间的生产关系,专业化解决相对的问题,从整体提升了解决问题的能力,尤其是解决复杂问题的整体能力。

由此,我们要提升我们的业务和管理生产力就得从此着手,软件世界中的构件化(Componentization)正承担了这一使命。原来的应用系统则不断地被构件化所打破,企业逐渐走上‘一个应用’的进阶。企业渐渐不再有固定的应用系统,取而代之的是处于各个层面的模块构件来实现某个层面的相应功能。下图是构件化企业应用的一个范例。

 
 
企业应用通过底层的技术构件来作为实现应用的基础技术功能,技术构件的适用性往往是最为广泛和跨行业的,在各种应用中都会被高度复用。而再上一层的则是企业根据业务总体模型设计出来或是在不断的应用项目实践中不断提炼归纳出来的某个业务或是管理域的业务构件,这些业务构件往往是企业最为重要的资产和竞争能力。有了这些业务构件,企业就可以根据具体要实现的业务和管理流程,组成具体的应用实现,满足业务的需求。

业务构件化和技术构件化的逻辑模式首先让企业可以开始不断规划设计、项目积累和梳理回归不同层次上的技术构件、业务构件和业务流程,通过专业化分工和流程协同达到组织级能力的提升。并且在此过程中和基础上可以更为精细化地运营和管理。企业根据需要灵活注入对于业务和技术构件的管控和治理策略,从而找到自身的核心能力模块,找到自身的高利润业务职能模块。进而不断投入、扩展和优化自身的核心优势能力,限制、调整和外包自身的劣势能力,达到不断提升企业整体竞争能力和赢利能力的目的。

构件化通过模块化和层次化,梳理优化生产关系;通过专业化和流程协同提升组织级生产力。

SOA通过构件标准化和服务契约化,推进软件生产力

构件化在不同的技术背景和时代有着不同的能力表现,在SOA到来之前构件化只能有效实现技术层面的模块化、层次化和专业化的能力水平。而SOA时代则真正带来了业务和管理的模块化、层次化和专业化。下图就是SOA编程模型SCA中定义的标准原子构件。

很显然它的技术无关性和消费使用(Consume)特征,如:服务、引用、属性、实现,是实现业务构件化的关键所在。原子构件就可以是一个事实上的业务构件,当然也可以在原子构件的基础上进行业务组装形成更大粒度的组合构件(Composite)。进而若干个组合构件和资源配置文件形成构件包(Contribution),成为独立可部署的业务功能模块。业务功能模块有了SOA标准下的逻辑构件形态和物理构件形态后,就可开发、可部署、可运行和可管理了,也就真正实现了标准的业务构件化。

下图是一个构件化SOA应用的范例。


 
由业务模块形成的标准化构件(Component/Composite)实现各自分工的业务功能,并通过契约化的SOA服务和引用互相协作,从而实现了一个典型场景下的业务应用。这样构件化的SOA应用,业务分工明确,组织协同关系清晰,可管理性、业务复用度和组织级灵活性都更为高效。

这就是SOA从面向构件开始,梳理优化生产关系,协同专业化发展组织能力,进而实现软件生产力的跨越。

后注:1969年6月23日,美国司法部通过了著名的反托拉斯法案后,IBM不得不宣布不再免费随机提供软件,从而开始为其硬件和软件分别定价。那一天可以称为软件业的官方元年。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 精通Python设计模式需要对Python编程语言有深入的理解,并且熟悉常用的设计模式。设计模式是一种解决特定问题的经验总结,可以提供可复用的解决方案。 首先,精通Python设计模式需要掌握Python的基本语法和面向对象编程的概念。了解类、对象、继承、多态等概念并能够熟练运用。 其次,熟悉常用的设计模式。设计模式可以分为创建型、结构型和行为型三大类。常见的设计模式包括单例模式、工厂模式、观察者模式、策略模式、装饰器模式等。对于每个模式,需要了解其定义、适用场景和解决的问题,同时能够根据具体的问题选择合适的模式。 此外,还需要能够在实际项目中运用设计模式。通过合理地运用设计模式,可以提高代码的可复用性和可扩展性,降低系统的维护成本。在使用设计模式时,需要根据具体的需求和情况进行权衡,避免过度设计和滥用设计模式。 最后,持续学习和实践是精通Python设计模式的关键。设计模式是一种经验,需要在实际开发中不断使用和改进。通过参与开源项目、阅读优秀代码和交流讨论等方式,不断提高自己的设计模式能力。 总之,精通Python设计模式需要熟悉Python语言并掌握常用的设计模式,能够在实际项目中灵活运用。通过不断学习和实践,可以进一步提高自己的设计模式水平。 ### 回答2: 精通Python设计模式是指对Python语言中各种设计模式及其应用有深入理解和熟练掌握的能力。 首先,精通Python设计模式需要对Python语言本身有较高的掌握程度,熟悉Python的语法、数据类型、面向对象编程等基础知识。同时,需要了解Python常用的模块和库,如NumPy、Pandas、TensorFlow等,在项目中熟练运用。 其次,要精通Python设计模式,需要对常见的设计模式有深入的理解。设计模式是对软件设计经验的总结和抽象,可以解决某类问题,并且能够提供可复用的设计方案。常见的设计模式有单例模式、工厂模式、观察者模式、装饰器模式等。对于每种设计模式,我们需要了解它的定义、适用场景、优缺点以及实际应用中的注意事项等。 最后,精通Python设计模式也需要具备实际项目经验。通过实践中运用设计模式解决具体问题,可以加深对设计模式的理解,并掌握如何将设计模式应用于实际项目中。同时,通过项目经验还可以锻炼解决问题的能力和代码质量。 总而言之,精通Python设计模式是掌握Python语言、了解常见设计模式、具备实际项目经验的综合能力。通过深入学习和实践,可以提高代码的可维护性、复用性和扩展性,从而更好地应对复杂的软件设计和开发任务。 ### 回答3: 精通Python设计模式是指对Python编程语言中各种设计模式的理解和运用达到了高级水平。 首先,理解设计模式的概念是基础。设计模式是在软件开发过程中用于解决常见问题和提供可复用解决方案的经验总结。在精通Python设计模式前,必须熟悉常见的设计模式分类,如创建型模式、结构型模式和行为型模式,并了解每个设计模式的特点和适用场景。 其次,精通Python设计模式需要掌握Python语言的特性和语法。熟练使用Python的面向对象编程(OOP)特性,如封装、继承和多态,能够更好地理解并实现设计模式。同时,熟悉Python中的函数式编程(FP)特性,如高阶函数、闭包和装饰器,能够更好地应用某些设计模式,如策略模式和装饰器模式。 其次,熟悉和掌握各种设计模式的具体实现和应用。例如,对于创建型模式中的工厂模式,可熟练使用Python的工厂函数或元类实现;对于结构型模式中的适配器模式,可使用Python的继承或组合方式实现;对于行为型模式中的观察者模式,可利用Python的事件机制或回调函数实现。 最后,精通Python设计模式还需要对代码的质量和可维护性有一定的追求。设计模式并非银弹,不应盲目使用。在实际开发中,需要根据具体情况权衡设计模式的利弊,并结合项目的需求和团队的能力做出合理的选择和折中。 总的来说,精通Python设计模式需要综合考虑设计模式的基本概念、Python语言的特性和语法以及具体应用场景的需求,通过不断实践和学习,不断提高自己的设计思维和编码能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值