InfoQ

新闻

市场要求WCF进一步完善其应用性

作者 王翔(Vision Wang) 发布于 2007年9月24日 下午9时50分

社区
.NET
主题
.NET框架,
客户及需求
标签
WCF,
可用性

在.NET 3.0的4项技术(WF、WCF、WPF、WCS)中,WCF是最被国外同行所看好的技术,但应用中WCF却显得门槛有些太高,为了迎合开发市场的需要WCF在很多方面亟待进一步改善。

虽然开发社区对于.NET 2.0 加了4个“壳”就称之为.NET 3.0已经颇有微词很久,但更多的抱怨是在.NET 3.0走出神话、走入项目之后,其中WCF作为相对位置比较底层的新一代分布式组件技术成为抱怨的焦点。与COM+、.NET Remoting、XML Web Service推出时的情况相比,微软的商业宣传似乎分量更足,但实际提供的参考手册发示例相比明显“缺斤短两”。虽然在各种活动中,WCF充分体现出很多优异表现(跨平台调用、隔离具体组件技术、充分利用各种WS-*协议、大幅降低编码量、几乎完全基于配置等),但相信您也注意到,与其他介绍不同,WCF的介绍都会提前把很长的配置文件写好,介绍的时候讲师总是说“时间关系,下面我们导入一个之前配置好的文件”。

从项目实施人员的角度看,WCF的主要问题其时不在于其API功能的丰富性,关键因素是使用它太麻烦:

  • 与WF、WPF相比,WCF在Visual Studio.NET里的插件太过简单,绝大部分时间只能依靠配置文件的XSD给开发人员一些提示,在增加配置节、配置元素的时候可以有一些简单的IntelliSense;
  • 虽然宣传文档里一直在说WCF的开发很多时候就是ABC(Address、Binding和Contract)的开发,但WCF似乎“大包大揽”的内容太多,以至于Windows Vista SDK中提供的文档远远不能满足很多开发工作,尤其在国内WCF都快成为“阳春白雪”的情况下,很少能找到适合自己项目的精简但比较完整的示例;
  • 之前ASP.NET、.NET Security和.NET Remoting的配置文件已经令很多开发人员和部署人员头疼不已,而WCF的配置文件Schema复杂程度很大程度上超越了他们三者的总和,加之各种WS-*标准升级过快,虽然WCF的ABC可以抽象分布式调用的逻辑部分,相对做到Write Once,但部署到一个新环境中WCF的配置文件的调整确实是一个非常痛苦的经历,因为WCF是一个“外壳”,很多时候CLR提示的错误信息对定位配置错误没有多少帮助,项目规模稍大的时候,在不同环境调整WCF文件很可能成为Crazy Anywhere的经历;
  • 而且对于已经使用WCF的同行而言,Visual Studio 2008也许意味着一个“新”体验的开始,因为从文件系统、队列到对象实体模型都作了较大的调整(尽管被命名为.NET 3.5),WCF功能上增加了一揽子新特性,项目中的WCF作为分布式组件是否需要一同升级要好好斟酌一下。不仅如此,从发布的Orcas看,WCF的配置文件愈发复杂了,但相应的工具并没有跟上;

即便有来自J2EE社区的压力,WCF在求新、求统一的情况下,为了照顾到开发市场的需要,必须要让自己做到“易用”。照顾好开发人员,很大程度上也等于照顾好自己的利润。

没有回复

回复

独家内容

专访开源项目Amoeba架构师陈思儒

DBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。

使用JSF、Ajax和Seam开发Portlets(2/3)

作为三期系列文章的第二部分,本文延续了上一期内容,介绍了RichFaces,包括如何把RichFaces集成到之前提到的示例应用中、如何部署RichFaces porlet和RichFaces的多种特性和功能。

Jeff Barr谈论Amazon Web服务

Amazon Web Services(AWS)的传道者Jeff Barr讨论了SimpleDB、S3、EC2、SQS、云计算、Amazon的不同服务如何与应用交互、AWS的起源、SimpleDB和微软SQL Server Data Services、AWS cloud的全球化、三月份的AWS停机。

用Erlang实现领域特定语言

Erlang的并发模型很有名,它的健壮性也很有名。但其他方面呢?在这篇文章里,Dennis Byrne演示了如何用Erlang建立内部DSL。

基于Rails的企业级应用剖析

本视频主要以FreeWheel为例,对一个基于Rails的企业级应用进行了剖析。其中包括:FreeWheel的架构、部署、数据库的问题、REST API、敏捷开发过程、如何去写测试以及持续集成等等。

JavaFX技术预览

JavaFX显示了Sun的Java系列产品市场方向的一个重大转变。随着1.0版的即将发布,InfoQ以JavaFX预览版为参考,与Sun高级工程师Joshua Marinacci探讨了即将发布的1.0正式版。

剖析短迭代

敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?

应用JSF、Ajax和Seam开发Portlets(1/3)

本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。