BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

架构妄想

| 作者 Boris Lublinsky 关注 1 他的粉丝 ,译者 李勇 关注 0 他的粉丝 发布于 2011年10月3日. 估计阅读时间: 3 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

William Vambenepe的最新文章,AJAX + REST是最新的架构妄想,让我们回想起了一个具有15年历史的架构,它曾被寄期望对Web产生革命性的影响。

在该架构里,Web服务器将返回包含全部数据的XML文件,与XML一道,还会返回一个XSLT文件(用于描述如何将XML转换成HTML)。浏览器将依此处理XML数据,显示最终的HTML。搞定!该方式将带来很多好处,优于老式的“服务器生成HTML”模型。XML可以被其他应用方便地使用(不仅仅是人类),不同的XSLT可被用来将内容适配到各种客户端平台。

光阴飞逝,但这种理念其实从未真正实现。现在,我们又快速地转向Ajax:

XML文档还在,尽管它通常被称为JSON。XSLT现在则是一大堆JavaScript。比起XSLT模型,这种模型有许多优势……它更灵活,可以实现小规模更新,以及部分页面刷新等等。但是,它是否也能够让架构保持清晰,使数据API与表现逻辑相分离呢?

Vambenepe解释了原因,尽管它看上去优雅并包含了所有的架构优点,但该模型在大多数情况下并不实际:

相同服务的客户端支持多种交互模型,若不无限制的蔓延开来,单个API很难满足所有这些模型的需要(这里,所谓“单一API”,其实就是一块遮羞布)。但若是想让API保持外观简洁,你最终可能就会得到交互频繁的应用。

但是在Vambenepe看来,这仅仅是该方法诸多问题中的一个。他指出的另一个大问题是该方法的事实:

……摒弃集成了浏览器代码和服务器代码的架构……不是所有Web开发者都认为他们的客户端框架和服务器框架是两套工具。将它们整体作为一个预先装配好的工具使用或许不会得到最优的代码,但可能还是可以最优利用你的开发资源。

尽管Vambenepe有强有力的论据,他的帖子还是遭到了质疑。什么才是正确之路?为现有UI(如GWT风格)创建/生成单独的REST API?一方面,这种方法简化了UI实现;另一方面,每个UI都要有一个新API。这种方法的伸缩性更好吗?哪个代价更高?实现UI集成,还是后端API?由这个帖子还产生了另一个更严肃的问题:什么是正确的设计方法?先实现后端API,然后设计多个使用它的UI;还是开始从UI开始设计,然后再定义支撑它的API?传统来看,API实现的代价似乎更高,但API本身要比UI更稳定。

因此,没错,满足各种需求的单一API看起来是架构妄想。但是,一组设计良好、轻巧可重用的API可被用来作为许多UI(Ajax)实现的基础。

查看英文原文:Architectural Mirages

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

本不应该是“妄想” by 王 锐

“一个API,多个用途”真的是一种架构妄想吗?我认为不是。在很多情况下之所以发生这种事情大多是由于很多人为因素导致的:架构设计中应用了反模式、实现过程中对于架构规格存在着误解、需求分析过程中缺乏深入的发掘……
在我们最终得出这样一个结论之前,我们应该至少考虑以下4点:
1、这个API是基于什么而构建的?是完全基于客户的需求,还是基于某种UI组件的技术特性?
2、这个API的输入和输出是否具有“语言中立性”?就像上面所提到的,尽管JSON是一种特殊格式的XML,但是它并不适用所有情况,所以为什么不取而代之使用标准格式的XML呢?
3、我们的开发工作真的是在基于用户的业务需求的基础上,而不在是某个技术人员的口头建议(尤其是对于一个很“酷”的UI功能的建议,并且和这个功能相关的需求并没有被列在需求列表上)的基础上来进行的吗?
4、API架构人员和API消费方之间的交流渠道健康吗?并且是否有一个可操作的用于架构发掘的途径(那些搞JavaScript的“酷小子”们真的理解他们所消费的API是干什么用的、怎么来用这个API吗)?

所以,依我所见,与其过早的下这样一个“近乎妄想”的结论,倒不如先对我们的软件过程中的具体细节进行一下仔细的检查。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

1 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT