普通程序员对SOA的理解与应用

时间:2022-09-10 11:26:23

普通程序员对SOA的理解与应用

摘 要:对于SOA的理解,大多数是更高层面的概念,专门面向大型软件的项目经理、软件架构师等等相对高端的软件设计人才。而对于基层的软件工程师和程序员能不能理解SOA的概念,应该怎样去理解进而可以让SOA的设计思想更加平民化,是本文描述的重点。

关键词:SOA;SCPI

中图分类号:TP311

SOA是面向服务的设计架构(Service-oriented Architecture),相比面向对象设计来说,属于更高的一个层面。现在,大多数基于SOA设计都是非常庞大的软件系统。从某种意义上讲,SOA也是一个广义的概念,基于SOA的设计可以为大的系统软件设计基础运行平台,在基础运行平台上开发不同的功能。

对于SOA的理解,大多数是更高层面的概念,专门面向大型软件的项目经理、软件架构师等等相对高端的软件设计人才。而对于基层的软件工程师和程序员能不能理解SOA的概念,应该怎样去理解进而可以让SOA的设计思想更加平民化,是本文描述的重点。

SOA实际上和很多其他学术概念有很多相似的地方,比如基础平台加上应用这个概念和软件二次开发就非常类似,也和基于Frame Work的软件开发有很多相似的地方,Frame Work是基础平台,在Frame Work上开发的功能也能够理解为基于SOA的应用。无论是二次开发也好,Frame Work也好,基础平台类的程序一旦写好了代码就不需要再修改了,而基于基础平台的应用可以千变万化,尽可能地发挥我们的创造力。

从体系结构的角度,SOA是一种软件体系结构和软件构造方法。在软件的基础架构上,SOA架构能够实现服务部署环境和服务实现之间的松散耦合,以及不同功能的服务实现之间的松散耦合性,有利于提高分布式系统的可伸缩性,有利于实现对资源的动态优化配置,最大程度地资源共享。在软件的构造方法上,SOA打破了传统的分布式组件容器的界限,以服务作为基本构造计算单元,通过服务的组合和组装完成系统整体功能。

从实现技术的角度,SOA不仅是一种体系结构,更是指以松散耦合方式实现业务层面各种服务能力的共享、供给和重用的方法学。SOA包含了编程模型及软件工程方法学等在内的一整套系统构造方法和环境。虽然SOA技术与软件服务化的使用模式并没有必然的联系,但SOA软件构造技术所带来的松散耦合和软件的可组合等特性,都有助于软件的使用方式逐渐演化为“定制化使用”、“托管部署和运维”的服务化使用方式。

而从普通程序员的角度去考虑,全部可以归纳为代码实现技术方面的问题,从面向过程、面向对象和面向服务不同领域层次来提升自己的设计能力。首先,“面向过程”是一种以事件为中心的编程思想,使用算法+数据结构的方式就能够实现。而“面向对象”(Object Oriented,简称OO)是一种以事务为中心的编程思想,任何事务都可以抽象成为对象。如:一扇门可以看作是对象,汽车本身有颜色、大小、品牌、位置、运动与否、运动方向、速度等属性。面向服务是一种体系结构,是一个系统架构层次的概念,其所有的功能和服务都使用描述语言+定义,并且各自的接口都可以使用网络进行发现。

从普通程序员的角度考虑,从面向过程、面向对象到面向服务,都是面对不同软件规模的特定设计方式,以给自身的工作带来最大的方面为目的。而无论是面向过程还是面向服务,其设计实际上没有本质的区别,所有原则都可以遵循“封装”、“复用”、“再封装”、“再复用”的方法,区别只是规模不同。

总结:如果能够以普通程序员的角色理解SOA,对于广大基层程序员的设计水平来说可以得到很大的提升。从程序员层面理解SOA还涉及到代码复用技术、好的程序设计方法、数据结构设计和二次开发设计定义,也应该算作狭义的对SOA的理解。

参考文献:

[1]唐秀良.SOA发展探索与研究[J].中国电子科学学院学报,2009,5.

作者单位:天津市德力电子仪器有限公司,天津 300392

上一篇:寓教于乐,寓学于情 下一篇:新型网络安全管理在地面测发控网络中的研究与...