web浏览器中的javascript
- 客户端javascript
- 在html里嵌入javascript
- javascript程序的执行
- 兼容性和互用性
- 可访问性
- 安全性
- 客户端框架
window对象
- 计时器
- 浏览器定位和导航
- 浏览历史
- 浏览器和屏幕信息
- 对话框
- 错误处理
- 作为window对象属性的文档元素
- 服务消费方(client)以本地调用方式调用服务;
- client stub接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体;
- client stub找到服务地址,并将消息发送到服务端;
- server stub收到消息后进行解码;
- server stub根据解码结果调用本地的服务;
- 本地服务执行并将结果返回给server stub;
- server stub将返回结果打包成消息并发送至消费方;
- client stub接收到消息,并进行解码;
- 服务消费方得到最终结果。
二、什么是REST?
REST
是一种架构风格,指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful
。REST
规范把所有内容都视为资源,网络上一切皆资源。
REST
并没有创造新的技术,组件或服务,只是使用Web的现有特征和能力。 可以完全通过HTTP
协议实现,使用 HTTP
协议处理数据通信。REST
架构对资源的操作包括获取、创建、修改和删除资源的操作正好对应HTTP协议提供的GET、POST、PUT
和DELETE
方法。
REST
和RPC
的比较:RPC
来实现服务间调用的一些痛点:
RPC
服务提供方与调用方接口依赖方式太强,会导致编码的复杂性,而REST
接口相比RPC
更为轻量化,服务提供方和调用方的依赖只是依靠一纸契约,不存在代码级别的强依赖。RPC
服务对平台敏感,难以简单复用;REST
可以实现跨平台,任何一个语言的调用方都可以根据接口定义来实现。
2.1 统一接口
RESTful
架构风格规定,数据的元操作,即CRUD(create, read, update
和delete
,即数据的增删查改)操作,分别对应于HTTP
方法:GET
用来获取资源,POST
用来新建资源(也可以用于更新资源),PUT
用来更新资源,DELETE
用来删除资源,这样就统一了数据操作的接口,仅通过HTTP
方法,就可以完成对数据的所有增删查改工作。
即:
GET(SELECT)
:从服务器取出资源(一项或多项)。POST(CREATE)
:在服务器新建一个资源。PUT(UPDATE)
:在服务器更新资源(客户端提供完整资源数据)。PATCH(UPDATE)
:在服务器更新资源(客户端提供需要修改的资源数据)。DELETE(DELETE)
:从服务器删除资源。
2.2 URI
可以用一个URI
(统一资源定位符)指向资源,即每个URI
都对应一个特定的资源。要获取这个资源,访问它的URI
就可以,因此URI
就成了每一个资源的地址或识别符。
一般的,每个资源至少有一个URI与之对应,最典型的URI即URL。
2.3 无状态
所谓无状态的,即所有的资源,都可以通过URI
定位,而且这个定位与其他资源无关,也不会因为其他资源的变化而改变。有状态和无状态的区别,举个简单的例子说明一下。如查询员工的工资,如果查询工资是需要登录系统,进入查询工资的页面,执行相关操作后,获取工资的多少,则这种情况是有状态的,因为查询工资的每一步操作都依赖于前一步操作,只要前置操作不成功,后续操作就无法执行;如果输入一个url
即可得到指定员工的工资,则这种情况是无状态的,因为获取工资不依赖于其他资源或状态,且这种情况下,员工工资是一个资源,由一个url
与之对应,可以通过HTTP
中的GET
方法得到资源,这是典型的RESTful
风格。
RPC
与RESTful
的区别如下面两个图所示:
Dubbo
采用的RPC
的服务调用,SpringCloud
采用的REST
。
三、微服务通讯该如何选择
仍是需要从实际情况去考虑:
- 对性能有着严格的要求:
RPC
- 考虑学习成本,团队成员的上手难度以及开发效率成本:
REST
- 对外开放的需求,rpc需要进一步转换,而rest可直接对外开放:
REST
- 代码耦合度要求松散耦合:
REST
- 与其他框架集成的难度低,微服务框架基本支持
rest
:REST
- 异步需求,
rest
需要额外的实现手段,如通过中间件等:RPC