API 架构(RPC风格、RESTful风格)

API 架构风格笔记

RPC风格的接口案例

RPC(Remote Procedure Call,远程过程调用)风格的接口设计主要关注于远程服务调用的过程,而不强调资源的表述。以下是RPC风格接口的一个案例:

  1. 接口定义
    • 假设我们有一个远程服务,用于处理用户信息的查询和修改。
    • 接口方法可能包括:getUserInfo(userId: int) -> UserupdateUserInfo(userId: int, userInfo: User) -> bool
  2. 调用方式
    • 客户端通过RPC框架(如Dubbo、gRPC等)调用远程服务的方法。
    • 调用时,客户端无需关心底层网络通信的细节,只需按照接口定义传递参数和接收返回值。
  3. 数据格式
    • RPC请求和响应的数据格式通常使用二进制或自定义的序列化协议,以实现高效的数据传输和解析。
  4. 示例请求
    • 客户端通过RPC框架发送一个请求,请求中包含方法名getUserInfo和参数userId=123
  5. 示例响应
    • 远程服务处理请求后,返回一个包含用户信息的User对象给客户端。

RESTful风格的接口案例

RESTful(Representational State Transfer,表述性状态转移)风格的接口设计以资源为核心,强调资源的表述和状态转移。以下是RESTful风格接口的一个案例:

  1. 资源定义
    • 假设我们有一个Web服务,用于管理用户信息。
    • 资源可以是"用户"(User),对应的URI可能是/users/{userId}
  2. HTTP方法
    • 使用HTTP的GET、POST、PUT、DELETE等方法来表示对资源的不同操作。
    • 例如,GET /users/{userId} 用于获取用户信息,POST /users 用于创建新用户,PUT /users/{userId} 用于更新用户信息,DELETE /users/{userId} 用于删除用户。
  3. 数据格式
    • 请求和响应的数据格式通常使用JSON或XML,以易于人类阅读和机器解析。
  4. 示例请求(GET /users/123)
    • 客户端发送一个HTTP GET请求到/users/123
    • 请求头中可能包含认证信息(如Bearer Token)。
    • 请求体为空(因为GET请求通常没有请求体)。
  5. 示例响应(HTTP 200 OK)
    • 服务器返回一个HTTP 200 OK响应,表示请求成功。
    • 响应头中包含一些元数据,如Content-Type: application/json
    • 响应体中包含用户信息的JSON表示,如{"id": 123, "name": "John Doe", "email": "johndoe@example.com"}

两者比对

  1. 从接口名称来看

    • RESTful风格的接口名称通常使用名词来表示资源,遵循资源的层次结构。
      例如,对于获取用户信息的接口,可能会命名为/users/users/{userId},这样的命名方式更侧重于资源的访问,而不是具体的操作。
    • RPC风格的接口名称则通常包含动词,直接描述了服务的操作或动作。
      例如,getUserInfoaddUser等,这样的命名方式更侧重于服务的行为或功能。
  2. 从HTTP请求方法来看

    • RESTful风格严格遵循HTTP协议中定义的请求方法(GET、POST、PUT、DELETE等),每种方法都有明确的操作语义。
      例如,GET用于请求资源,POST用于创建新资源,PUT用于更新资源,DELETE用于删除资源。
    • RPC风格的接口在HTTP请求方法的使用上可能更加灵活或受限。
      有些RPC实现可能只使用POST或GET方法作为远程调用的载体,而不严格区分请求方法的具体语义。
  3. 从返回数据格式来看

    • RESTful风格通常使用JSON格式作为返回数据的标准格式,因为JSON具有轻量级、易于阅读和编写的特点,同时也易于机器解析和生成。RESTful风格的返回数据结构往往遵循一定的规范,便于客户端处理。
    • RPC风格的返回数据格式则可能更加多样化,它取决于具体的RPC框架和协议。虽然JSON也是一种常见的返回数据格式,但RPC也可能支持其他格式,如XML、Protobuf等。RPC风格的返回数据结构可能更加灵活,以适应不同的服务需求和传输场景。

总结

RPC和RESTful是两种不同的接口设计风格,

RPC更关注远程服务调用的过程,

而RESTful更关注资源的表述和状态转移。

在实际应用中,可以根据项目需求和团队偏好选择适合的接口设计风格。

相关推荐
龙山云仓6 小时前
MES系统超融合架构
大数据·数据库·人工智能·sql·机器学习·架构·全文检索
未来龙皇小蓝6 小时前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
Tadas-Gao6 小时前
深度学习与机器学习的知识路径:从必要基石到独立范式
人工智能·深度学习·机器学习·架构·大模型·llm
崎岖Qiu6 小时前
【计算机网络 | 第十篇】以太网的 MAC 层
网络·笔记·计算机网络·mac地址
BlackWolfSky6 小时前
鸿蒙高级课程笔记2—应用性能优化
笔记·华为·harmonyos
玄同7656 小时前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
符哥20086 小时前
C++ 适合初学者的学习笔记整理
c++·笔记·学习
ujainu6 小时前
让笔记触手可及:为 Flutter + OpenHarmony 鸿蒙记事本添加实时搜索(二)
笔记·flutter·openharmony
曦月逸霜6 小时前
Python快速入门——学习笔记(持续更新中~)
笔记·python·学习
啊森要自信6 小时前
CANN ops-cv:揭秘视觉算子的硬件感知优化与内存高效利用设计精髓
人工智能·深度学习·架构·transformer·cann