[解读REST] 2.REST用来干什么的?
衔接上文[解读REST] 1.REST的起源,介绍了REST的诞生背景。每当笔者遇到一个新事物的想去了解的时候,总是会问上自己第一个问题,这个新事物是干什么用的?在解释我所理解的REST这个过程中也不例外,这篇博客我们先关注一下REST是干什么用的,然后后续再解释REST是什么。好了,不说废话了,在上篇结尾处说到,REST是Web的架构风格,暂且不管REST和Web,我们先看看架构风格是什么东西?
1. 什么是架构风格?
计算机科学中,架构(Architecture)一词来源于建筑学,我相信大家在不少资料上都见过这样的解。那么同样的,架构风格(Arvhitecture Style)这个词语也和建筑学的建筑风格高度相似。比如我说起苏州园林、佛教建筑、古罗马建筑这几种风格的建筑。或许你可能和笔者一样对建筑学一窍不通,但是如果你面前有一栋建筑,你依然可以快速的分辨出这栋建筑到底是佛教建筑的还是古罗马建筑,为什么呢?因为它们有着很明显的特点可以区分看来,比如下图:

你总不会认为它是古罗马的建筑吧(虽然我说不上来具体有什么特征。。。但是它就是佛教建筑,你能把我咋滴)。
那么架构风格也是这么一个类似的概念,也有它自己的特征加以区分,我们把这些特征称为“架构约束”。那么架构风格的定义就是:一个架构风格是一组已命名的、相互协作的架构约束。所以,既然REST是Web的架构风格,那么也就是说有一组架构约束约束着Web?是的,正是如此。
2. Web的发展阶段
上篇说到,世界上的第一个网站在1990年12月20日诞生于Tim Berners-Lee(web之父)的一台NeXT电脑上,由一个简单的浏览器,html组成。而如今的Web已经不是当初的那个纯静态的网站了,早已渗透到了社会的各个方面。
如今Web的规模在成几何指数的增长着,从早期的纯静态的网站 -> CGI->脚本语言(php,jsp,asp)-> AJAX -> RIA(Flash,Silverlight)-> SPA -> Web App -> PWA(Google提出的渐进式Web APP)。在这个发展过程中,有没有发现,其中支撑Web发展的核心标准规范(HTTP,URI和HTML),一直都没有根本性的变化。
1996年HTTP0.9的时候一直处于纯静态的网站的阶段;1996年HTTP1.0引入了POST,从此迈入了CGI的时代;再到1999年HTTP1.1发布的时候,脚本语言(php,jsp.asp)已经大展身手了(国内的BAT和早期的三大门户(网易,新浪,搜狐),国外的雅虎,谷歌均诞生于这几年间)。而自从1999年发布的HTTP1.1,到如今的2017年,支撑了整个Web快速发展的10几年,2015年正式发布的HTTP/2,几乎没有对HTTP1.1的协议语义方面做任何修改,而重点在于提升底层TCP的传输性能。
URI自从1998年以来,就没发生过什么变化。
HTML倒是变化不少,不过重点都是在于新标签,新API方面,而a,img,link,script和form这类超媒体控件元素一直都是非常稳定的。
再看看如今一个web应用运行的时候,都有那些部分会参与其中:
- JS;
- CSS;
- 图片,视频,音频;
- SOCKS,SSL/TLS;
- 来源服务器(apache,ngnix,iis)
- 应用服务器(tomcat)
- 网关(CGI,反向代理)
- 用户代理(chrome,firefox,ie,早期的网景)
- 客户端库(curl,wget,各种语言平台的httpclient库)
- 浏览器缓存,CDN,网络运营商缓存
等等,而这些部分在这20年间,发生了无数次的独立部署和升级,又有无数的组件已经退出了历史舞台。Web的面貌本身也以及发生了翻天覆地的变化,而Web的最核心的三部分(HTTP,URI,HTML)却保持着相对稳定的状态。这里面是不是有些值得思考的东西?有哪一个系统能像如今的Web系统这样,在20多年间,核心组成部分可以保持稳定,并且支撑了如此大的规模发展。
3. REST用来干什么的?
Web得以如此规模的发展,这和Web诞生之初的架构设计是分不开的。而REST则是用来发现,识别Web的架构模型中,有哪些地方需要改善,哪些地方需要说不的。所以,想要理解REST是什么,必须要站在俯览Web的角度,以Web的上帝视角来看待Web,才能搞清楚REST对Web到底做了些什么。很多的人只关注于restful的web api,以api的角度去理解解释rest,最终只会发现到头来就是URL设计的漂亮一些,把HTTP动词用起来,然后你就会发现REST也不过如此,也不好用,还遗留一堆问题。或许你会觉得少了些什么,然而也说不上来到底少了什么。其根本原因在于看待REST的视角选的不合适。REST是用来指导Web架构的设计和开发的,REST关注组件的可伸缩性、接口的通用性、组件的独立进化部署以及通过减少交互带来的延迟等等,它的关注点是Web;而不是如何设计URI,如何使用http method;而这些仅仅只是REST的附属的一个外在特征而已,并非REST的核心关注点。
4. 总结
笔者感觉这篇文章好像全是大空话,,,哈哈哈。不过也就只有一个目的,简单的类比解释下什么是架构风格,以及应该以怎样的视角看待REST(就像玩积木一样,开Web的上帝视角)。本篇均是笔者自己的一些理解,不免有错误之处,欢迎指正。。
参考资料
架构(Architecture):https://en.wikipedia.org/wiki/Architecture
HTTP 0.9 :https://www.w3.org/Protocols/HTTP/AsImplemented.html
HTTP 历史:https://www.w3.org/Protocols/History.html
HTTP 1.1 : https://www.ietf.org/rfc/rfc2616.txt
Evolution of HTTP:https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Evolution_of_HTTP
理解本真的REST:http://www.infoq.com/cn/articles/understanding-restful-style/
Roy Fielding谈Google SPDY协议:http://www.infoq.com/cn/news/2012/07/roy-on-google-spdy
架构风格与基于网络应用软件的架构设计(中文修订版):http://www.infoq.com/cn/minibooks/web-based-apps-archit-design
Architectural Styles and the Design of Network-based Software Architectures:https://www.ics.uci.edu/~fielding/pubs/dissertation/top.htm
[解读REST] 2.REST用来干什么的?的更多相关文章
- [解读REST] 3.基于网络应用的架构
链接上文[解读REST] 2.REST用来干什么的?,上文中解释到什么是架构风格和应该以怎样的视角来理解REST(Web的架构风格).本篇来介绍一组自洽的术语,用它来描述和解释软件架构:以及列举下对于 ...
- runtime 运行时机制 完全解读
runtime 运行时机制 完全解读 目录[-] import import 我们前面已经讲过一篇runtime 原理,现在这篇文章主要介绍的是runtime是什么以及怎么用!希望对读者有所帮助! ...
- 开心菜鸟系列----变量的解读(javascript入门篇)
console.info( console.info(window['weiwu']) console.info(window. ...
- nodeJS之eventproxy源码解读
1.源码缩影 !(function (name, definition) { var hasDefine = typeof define === 'function', //检查上下文环境是否为AMD ...
- AbstractQueuedSynchronizer源码解读
1. 背景 AQS(java.util.concurrent.locks.AbstractQueuedSynchronizer)是Doug Lea大师创作的用来构建锁或者其他同步组件(信号量.事件等) ...
- php-msf 源码解读【转】
php-msf: https://github.com/pinguo/php-msf 百度脑图 - php-msf 源码解读: http://naotu.baidu.com/file/cc7b5a49 ...
- Spark Streaming源码解读之流数据不断接收和全生命周期彻底研究和思考
本节的主要内容: 一.数据接受架构和设计模式 二.接受数据的源码解读 Spark Streaming不断持续的接收数据,具有Receiver的Spark 应用程序的考虑. Receiver和Drive ...
- tpcc-mysql运行结果解读
前言 首先我们需要知道tpcc-mysql是干什么的.TPC-C是专门针对联机交易处理系统(OLTP系统)的规范,一般情况下我们也把这类系统称为业务处理系统.tpcc-mysql是percona基于T ...
- 数人云CTO解读Docker 1.12和金融业容器化
7月29日 数人云 在上海举办金融沙龙,邀请上交所和近二十家来自银行.保险.证券的IT技术专家一同探讨容器技术在金融业中的最佳实践.数人云CTO肖德时在会上将传统金融行业通过容器可以解决的四大问题做了 ...
随机推荐
- Java提取URL某个参数的值
Java提取Url中某个参数的值. public static String getParam(String url, String name) { String params = url.subst ...
- EF和Dapper之争的关键
突然发现园子里为EF和Dapper的事闹翻了天.(学Java的同学大概就是Hibernate和MyBatis之争了) 讲到EF对Mysql的支持,我在一边偷着乐:还好我用的是NHibernate,对M ...
- vue2.0 日历日程表 ,可进行二次开发.
由于工作业务需求,要写一个日程表,日程表写之前 要先生成日历,废话不多说,直接 上代码: <!DOCTYPE html> <html lang="zh-CN"&g ...
- 分布式架构原理解析,Java开发必修课
1. 分布式术语 1.1. 异常 服务器宕机 内存错误.服务器停电等都会导致服务器宕机,此时节点无法正常工作,称为不可用. 服务器宕机会导致节点失去所有内存信息,因此需要将内存信息保存到持久化介质上. ...
- PHP获取远程http或ftp文件的md5值
PHP获取本地文件的md5值: md5_file("/path/to/file.png"); PHP获取远程http文件的md5值: md5_file("https:// ...
- volatile关键字的特性及证明
volatile是java虚拟机提供的轻量级的同步机制 JMM(Java内存模型)是围绕着并发编程中原子性.可见性.有序性这三个特征来建立的 原子性:一个操作或多个操作要么全部执行完成且执行过程不被中 ...
- 部署tomcat环境
1.安装java jdk Java环境变量配置 2.下载64位tomcat https://tomcat.apache.org/download-70.cgi 3.配置service 打开cmd,执行 ...
- 从壹开始微服务 [ DDD ] 之六 ║聚合 与 聚合根 (下)
前言 哈喽大家周二好,上次咱们说到了实体与值对象的简单知识,相信大家也是稍微有些了解,其实实体咱们平时用的很多了,基本可以和数据库表进行联系,只不过值对象可能不是很熟悉,值对象简单来说就是在DDD领域 ...
- 【机器学习】--EM算法从初识到应用
一.前述 Em算法是解决数学公式的一个算法,是一种无监督的学习. EM算法是一种解决存在隐含变量优化问题的有效方法.EM算法是期望极大(Expectation Maximization)算法的简称,E ...
- NormalDialogFragmentDemo【普通页面的DialogFragment】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 该Demo主要演示DialogFragment作为普通页面,显示全屏和状态栏下方的效果以及动画效果. 效果图 代码分析 @Overr ...