两种常见的分布式应用架构风格包括:DO(分布式对象)、RPC(远程过程调用)。这两种架构风格在企业应用中得到了广泛的应 用,然而,Web架构的设计者们却有意避免采用这两种架构风格。主要的原因是运行Web应用的互联网环境,与运行企业应用的企业内网环境有很大的差别。 那么,互联网环境有哪些独有的特点呢? 1. 可伸缩性要求难以预测和无法控制:一个Web应用的并发访问量,是开发者难以预测和无法控制的。 2. 安全性要求难以预测和无法控制:一个Web应用所接受的请求格式,是开发者难以预测和无法控制的,有可能出现大量恶意构造的请求格式。 3. 松耦合至关重要:因为存在着大量异构的系统,必须要追求最大限度的松耦合。 4. 简单性至关重要:不可引入复杂的编程模型,必须降低开发者开发Web应用的门槛。
软件应用所处的运行环境会对其架构设计产生巨大影响。设计软件应用的架构,一定要深入考虑软件所处的运行环境。脱离开软件所处的运行环境,比较不同架构 之间的优劣是没有意义的。
REST这种架构风格,正是为面向互联网的Web应用量身定制的。它由一组架构约束组成: 1. 客户-服务器 2. 无状态 3. 缓存 4. 统一接口 5. 分层系统 6. 按需代码(可选)
上述内容来自《REST实战》译者序。.NET上的分布式应用架构风格从WCF开始统一了Remoting,SOAP,以及对REST的支持。现在我们来看下最新的.NET平台上都有哪些REST框架和工具库: