RESTful架构与RPC架构
RESTful架构与RPC架构
在RESTful
架构中,关注点在于资源,操作资源时使用标准方法检索并操作信息片段,在RPC
架构中,关注点在于方法,调用方法时将像调用本地方法一样调用服务器的方法。
RESTful架构
REST
即表述性状态传递Representational State Transfer
,是一种软件架构风格,也可以称作是一种设计API
的模式,REST
通过HTTP
协议定义的通用动词方法GET
、POST
、PUT
、DELETE
,以URI
对网络资源进行唯一标识,响应端根据请求端的不同需求,通过无状态通信,对其请求的资源进行表述,符合REST
设计规范的架构就称为RESTful
架构。
主要原则
- 网络上的所有事物都被抽象为资源
- 每个资源都有一个唯一的资源标识符
- 对资源的各种操作不会改变资源标识符
- 所有的操作都是无状态的
- 同一个资源具有多种表现形式如
xml
、json
等
统一资源接口
安全性是指访问REST
接口时不会对服务端资源状态发生改变。
幂等性是指对于同一REST
接口的URI
多次访问时,得到的资源状态是相同的。
GET
: 安全的,幂等的,用于读取资源POST
: 不安全的,不幂等的,用于服务端自动产生的实例号创建资源,更新部分资源PUT
: 不安全的,幂等的,用于客户端的实例号创建资源,更新资源DELETE
: 不安全的,幂等的,用于客户端实例号删除资源
实例
- 查询
user
,GET https://127.0.0.1/user/1
,通过直接携带params
查询用户 - 新增
user
,POST https://127.0.0.1/user
,请求body
附带用户注册信息 - 修改
user
,PUT https://127.0.0.1/user
,请求body
附带userid
标识信息 - 删除
user
,DELETE https://127.0.0.1/user
,请求body
附带userid
标识信息 - 通过请求头
Accept
来获取同一资源的不同形式,如application/json
与application/xml
等 - 若将版本号看作同一资源的不同表现形式的话,同样应该在
Accept
字段来区分版本而不是直接在URI
中添加版本号
RPC架构
RPC
即远程过程调用Remote Procedure Call
,简单的理解是一个节点请求另一个节点提供的服务,远程过程调用,是相对于本地过程调用来说的,当调用方法时就像调用本地方法一样调用远程服务器的方法,做到了轻量、无感知通信。
结构组成
- 客户端
client
:服务的调用方 - 服务端
server
:服务的提供方 - 客户端存根
client stub
:将客户端请求参数打包成网络消息,再发给服务方 - 服务端存根
server stub
:接收客户端发来的消息,将消息解包,并调用本地方法
通信过程
客户端
1. 将这个调用映射为Call Id
2. 将这个Call Id与参数等序列化,以二进制形式打包
3. 将序列化数据包通过网络通信发送到服务端
4. 等待服务端响应
5. 服务端调用成功并返回结果,反序列化后进行下一步操作服务端
1. 在本地维护一个Call Id的Map,用以保证Id与调用方法的对应
2. 等待客户端请求
3. 得到一个请求后,将数据包反序列化,得到Call Id与参数等
4. 通过Map寻找Call Id所对应的函数指针
5. 通过函数指针调用函数,并将数据包反序列化后的参数传递,得到结果
6. 将结果序列化之后通过网络通信返回到客户端注:
此处的客户端指的是本地调用者,也可以是一台服务器
此处的服务端指的是被调用者,也可以是一台服务器
数据包通信时无论是使用socket进行TCP传输,或使用HTTP进行传输都是可行的
相关比较
- 在通信协议方面来说,
RESTful
是使用HTTP
协议进行数据传输,RPC
一般是使用TCP
协议数据传输,当然传输协议并不是RPC
的重点,一般使用TCP
协议传输是因为其效率高,使用HTTP
协议传输是完全可行的。 - 在性能方面,
RPC
的传输效率高于RESTful
数据传输的效率,因为RCP
具有高效紧凑的进程通信机制,且传输数据量小,在交换大量消息时效率高。 - 在灵活度方面,
RESTful
架构的灵活度高于RPC
架构,使用RESTful
架构具有比较好的可读性,RPC
在编写与调试时略显繁琐。 - 使用
RESTful
架构的接口进行数据传输可以得到多语言支持,HTTP
协议相对更规范、更通用、更标准,对于中间件而言最先支持的几种协议都包含RESTful
数据传输规范。 - 内部服务的相互调用推荐使用
RPC
,而对外的接口推荐使用RESTful
,例如微服务架构模式一般就采用对内RPC
对外RESTful
的模式。
每日一题
https://github.com/WindrunnerMax/EveryDay
参考
https://www.jianshu.com/p/7d6853140e13
https://www.jianshu.com/p/ee92c9accedd
https://www.zhihu.com/question/28570307
https://www.zhihu.com/question/25536695
https://www.runoob.com/w3cnote/restful-architecture.html
https://blog.csdn.net/bieleyang/article/details/76272699
https://blog.csdn.net/u014590757/article/details/80233901
RESTful架构与RPC架构相关推荐
- 分布式 RPC架构简单理解
RPC框架 RPC(Remote Promote Call) 一种进程间通信方式.允许像调用本地服务一样调用远程服务. RPC框架的主要目标就是让远程服务调用更简单.透明.RPC框架负责屏蔽底层的传输 ...
- RPC框架的实现原理,及RPC架构组件详解
RPC的由来 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时, ...
- python前端调用后端模型_前端调用后端的方法(基于restful接口的mvc架构)
1.前端调用后台: 建议用你熟悉的一门服务端程序,例如ASP,PHP,JSP,C#这些都可以,然后把需要的数据从数据库中获得,回传给客户端浏览器(其实一般就是写到HTML中,或者生成XML文件)然后在 ...
- 基于Netty的RPC架构实战演练
基于Netty的RPC架构实战演练 NIO netty服务端 netty客户端 netty线程模型源码分析(一) netty线程模型源码分析(二) netty5案例学习 netty学习之心跳 prot ...
- RPC架构组件详解刨析
一个基本的RPC架构里面应该至少包含以下4个组件: 1.客户端(Client):服务调用方(服务消费者) 2.客户端存根(Client Stub):存放服务端地址信息,将客户端的请求参数数 据信息打包 ...
- 什么是系统架构?系统架构的特点分析!
系统构架是对已确定的需求的技术实现构架.作好规划,运用成套.完整的工具,在规划的步骤下去完成任务.抽象来说,它是计算机系统结构,或称计算机体系结构,是一个系统在其所处环境中最高层次的概念:它确定一台计 ...
- 微服务架构与SOA架构
传统项目架构 传统项目分为三层架构,将业务逻辑层.数据库访问层.控制层放入在一个项目中. 优点:适合于个人或者小团队开发,不适合大团队开发. 分布式项目架构 根据业务需求进行拆分成N个子系统,多个子系 ...
- SpringCloudSpringCloud Alibaba、微服务架构、网站架构演变过程、Nacos、Feign远程调用、Load Balancer负载均衡、Sentinel限流、Hystriy
什么是微服务? 微服务架构就是将单体的应用程序分成多个应用程序,这多个应用程序就成为微服务,每个微服务运行在自己的进程中,并使用轻量级的机制通信.这些服务围绕业务能力来划分,并通过自动化部署机制来独立 ...
- 微服务架构 之 互联网项目架构演变过程 (单点架构,模块化架构,分布式架构,soa架构,微服务架构)
一.什么是单点系统(传统架构)? 1.传统的SSH,SSM 架构,分为三层架构 web控制层.业务逻辑层.数据库访问层. 2. 传统架构也就是单点应用,就是大家在刚开始初学JavaEE技术的时候SSH ...
最新文章
- 你的大脑里有AI吗?
- Git config 查看和设置配置信息
- git 几种情况的回滚
- 转:怎样在VMware ESXi上 克隆虚拟机
- python word模板 图_科学网—Python绘制可插入Word的高清矢量图(SVG转EMF) - 任晓东的博文...
- 非直接缓冲区与直接缓冲区
- linux usb摄像头UVC usb3300 stm32F4
- 用户一键登陆,如何实现?了解一下!
- 新的 systemctl 命令代替原来的 chkconfig、service 命令
- win7装xp双系统_UEFI新PC装Win7 32位系统:巧用”硬盘保护卡“解决
- win11安装使用安卓子系统WSA
- 学习linux压缩命令压缩文档
- 量化高频交易从0到1(期货CTP,纳秒级,高频、趋势及套利策略)课程大纲
- 艺赛旗(RPA)Python 学习之异常
- 用Altium Designer软件绘制一个stm32最小系统的电路原理图
- 眼睛卫士Linux版
- 解决按照别人教程将系统中文名修改为英文名后无法登录问题
- 【免费】安卓性能测试工具GT
- 华云天下智能坐席助手 企业客服提效好帮手
- WiFi万能钥匙原理和危害探究
热门文章
- 国嵌视频光盘及源码网盘下载地址-续
- 利用PHP安装windows自动运行的服务,PHP程序可以实现长时间、自动运行、定时更新功能,直接可以用在项目中的类源代码...
- DownloadManager不好用?试试ZlsamDownloadService
- 将byte数组写进文件,指定buffer size
- 使用delphi 开发多层应用(十六)使用XMLRPC 实现basic4android 远程调用RTC服务
- Criteria和DetachedCriteria区别应用
- 得到节点值的两种方法
- GCC:使用图对比编码的图神经网络预训练模型 KDD2020
- HAN - Heterogeneous Graph Attention Network 异构图注意力网络 WWW2019
- VS2010连接MySql数据库时无法选择mysql database数据源