AIP-133 标准方法:Create
编号 | 133 |
---|---|
原文链接 | AIP-133: Standard methods: Create |
状态 | 批准 |
创建日期 | 2019-01-23 |
更新日期 | 2019-01-23 |
在REST API中,通常向集合URI(如 /v1/publishers/{publisher}/books
)发出POST请求,在集合中创建新资源。
面向资源设计(AIP-121)提供Create方法,遵循这一模式。这些接口接受上级集合和欲创建资源(可能还有其他参数),返回新建的资源。
指南
API通常 应当 为资源提供Create方法,除非这个操作对用户没有意义。Create方法的目的是在现有集合中创建新资源。
Create方法使用以下模式指定:
rpc CreateBook(CreateBookRequest) returns (Book) {option (google.api.http) = {post: "/v1/{parent=publishers/*}/books"body: "book"};option (google.api.method_signature) = "parent,book";
}
- 接口的名字 必须 以单词Create开头,其余部分 应当 是目标资源的单数形式。
- 请求消息 必须 与接口名字一致,并带有
Request
后缀。 - 应答消息 必须 是资源本身。不存在
CreateBookResponse
。- 应答 应当 包括完整资源数据, 必须 包括所有支持的域,仅输入域除外(参考AIP-203)。
- 如果Create接口是长运行创建,应答消息 必须 是解析为资源本身的
google.longrunning.Operation
。
- HTTP动词必须是
POST
。 - 添加新资源的集合 应当 映射到URI路径。
- 集合的上级资源 应当 称为
parent
, 应当 是URI路径中唯一的变量。 - 集合标识符(例子中的
books
) 必须 是字面值字符串。
- 集合的上级资源 应当 称为
google.api.http
注解中 必须 包含body
键, 必须 映射到请求消息中的资源域。- 所有其他域 应当 映射到URI查询参数。
- 应当 存在一个
google.api.method_signature
注解,值为"parent,{resource},{resource}_id"
。如果不需要资源I标识,值为"parent,{resource}"
。 - 如果API在[BROKEN LINK: 管理平面]上运行,则操作应具有[BROKEN LINK: 强一致性]:创建操作的完成必须意味着所有用户可设置的值和资源的存在已达到稳定状态,并且读取资源状态返回一致的应答。
请求消息
创建方法实现了一个常见的请求消息模式:
```proto message CreateBookRequest { / 将在其中创建此书籍的上级资源。 / 格式:publishers/{publisher} string parent = 1 [ (google.api.field_behavior) = REQUIRED, (google.api.resource_reference) = { child_type: “library.googleapis.com/Book” }];
/ 用于书籍的ID,将成为书籍资源名字的最终组成部分。 / / 此值应为4-63个字符,有效字符为[a-z][0-9]-/。 string book_id = 2 [(google.api.field_behavior) = REQUIRED];
// 要创建的书籍。 Book book = 3 [(google.api.field_behavior) = REQUIRED]; } ```
- 必须包含一个parent域,除非正在创建的资源是顶级资源。它应称为parent。
- 该域应被注释为必需([BROKEN LINK: AIP-203])。
- 该域必须标识正在创建的资源的[BROKEN LINK: 资源类型]([BROKEN LINK: AIP-123])。
- 对于管理平面资源,必须包含{resource}_id域,对于数据平面资源,应包含该域。
- 必须包含资源域,并且必须映射到POST主体。
- 请求消息不得包含任何其他必需域,并且不应包含其他可选域,除非在此或另一个AIP中描述。
长运行创建
某些资源创建资源所需的时间比常规API请求合理的时间长。在这种情况下,API应使用长运行操作([BROKEN LINK: AIP-151]):
```proto rpc CreateBook(CreateBookRequest) returns (google.longrunning.Operation) { option (google.api.http) = { post: “/v1/{parent=publishers/*}/books” body: “book” }; option (google.longrunning.operation_info) = { response_type: “Book” metadata_type: “OperationMetadata” }; } ```
- 应答类型必须设置为资源(如果接口不是长运行,则返回类型将是该资源)。
- 必须指定response_type和metadata_type域。
重要提示: 声明友好资源([BROKEN LINK: AIP-128])应使用长运行操作。如果请求实际上是立即的,则服务可以返回已设置为完成的LRO。
用户指定的ID
如果API在[BROKEN LINK: 管理平面]上运行,则API必须允许用户在创建时指定资源的ID组件(资源名字的最后一段)。
在[BROKEN LINK: 数据平面]上,API应允许用户指定ID。特殊情况应具有以下行为:
- 数据平面资源允许相同的记录,无需区分两者(例如,没有主键的表中的行)。
- 数据平面资源不会在[BROKEN LINK: 声明客户端]中公开。
API可以允许{resource}_id域具有[BROKEN LINK: field_behavior] OPTIONAL,并在未指定时生成系统生成的ID。
例如:
``` // 使用用户指定的ID。 publishers/lacroix/books/les-miserables
// 使用系统生成的ID。 publishers/012345678-abcd-cdef/books/12341234-5678-abcd ```
- {resource}_id域必须存在于请求消息上,而不是资源本身。
- 该域可以是必需的或可选的。如果它是必需的,则应包括相应的注释。
- 必须忽略资源上的name域。
- 接口上应恰好有一个google.api.method_signature注释,如果正在创建的资源不是顶级资源,则其值为"parent,{resource},{resource}_id",如果正在创建的资源是顶级资源,则其值为"{resource},{resource}_id"。
- 文档应解释可接受的格式是什么,并且格式应遵循[BROKEN LINK: AIP-122]中资源名字格式的指南。
- 如果用户尝试创建具有会导致重复资源名字的ID的资源,则服务必须返回ALREADY_EXISTS错误。
- 但是,如果进行调用的用户没有权限查看重复资源,则服务必须返回PERMISSION_DENIED错误。
注意: 对于REST API,用户指定的ID域{resource}_id作为请求URI上的查询参数提供。
错误
参考错误,特别是[BROKEN LINK: 何时使用PERMISSION_DENIED和NOT_FOUND错误]。
进一步阅读
- 有关在Create方法中确保幂等性,请参考[BROKEN LINK: AIP-155]。
- 有关涉及Unicode的资源命名,请参考[BROKEN LINK: AIP-210]。
理由
要求用户指定的ID
[BROKEN LINK: 声明客户端]使用资源ID作为应用更新和冲突解决的一种方式。缺少用户指定的ID意味着客户端无法找到资源,除非他们在本地存储标识符,并且可能导致重新创建资源。这反过来又对所有引用它的资源产生下游影响,迫使它们更新到新创建资源的ID。
拥有用户指定的ID还意味着客户端可以预先计算资源名字并在其他资源的引用中使用它。
修订记录
- 2023-10-20 澄清{resource}_id仅对管理平面资源是必需的。
- 2023-08-24 添加一致性要求。
- 2023-05-11 更改关于resource_id的指南为必须。
- 2022-11-04 引用AIP-193中的聚合错误指南,类似于其他CRUDL AIP。
- 2022-06-02 更改后缀描述以消除多余的“-”。
- 2020-10-06 添加声明友好指南。
- 2020-08-14 更新错误指南以使用permission denied而不是forbidden。
- 2020-06-08 添加关于返回完整资源的指南。
- 2019-11-22 添加关于发送重复名字时使用何种错误的澄清。
- 2019-10-18 添加关于注释的指南。
- 2019-08-01 将示例从“shelves”更改为“publishers”,以提供更好的资源所有权示例。
- 2019-06-10 添加长运行创建的指南。
- 2019-05-29 添加对标准方法中任意域的明确禁止。
相关文章:
AIP-133 标准方法:Create
编号133原文链接AIP-133: Standard methods: Create状态批准创建日期2019-01-23更新日期2019-01-23 在REST API中,通常向集合URI(如 /v1/publishers/{publisher}/books )发出POST请求,在集合中创建新资源。 面向资源设计&#x…...
大一计算机的自学总结:位运算的应用及位图
前言 不仅异或运算有很多骚操作,位运算本身也有很多骚操作。(尤其后几个题,太逆天了) 一、2 的幂 class Solution { public:bool isPowerOfTwo(int n) {return n>0&&n(n&-n);} }; 根据二进制表示数的原理&#…...
2025年01月28日Github流行趋势
项目名称:maybe 项目地址url:https://github.com/maybe-finance/maybe项目语言:Ruby历史star数:37540今日star数:1004项目维护者:zachgoll, apps/dependabot, tmyracle, Shpigford, crnsh项目简介ÿ…...
java基础-容器
一、集合基础 1、集合 Collection接口下,主要用于存放单一元素Map接口下,用于存放键值对 2、常见集合的比较 List 存储的元素是有序的、可重复的。Set: 存储的元素不可重复的。Queue: 按特定的排队规则来确定先后顺序,存储的元素是有序的、…...
PythonFlask框架
文章目录 处理 Get 请求处理 POST 请求应用 app.route(/tpost, methods[POST]) def testp():json_data request.get_json()if json_data:username json_data.get(username)age json_data.get(age)return jsonify({username: username测试,age: age})从 flask 中导入了 Flask…...
Android 启动流程
一 Bootloader 在嵌入式系统中,Bootloader的引导过程与传统的PC环境有所不同,主要是因为嵌入式系统的硬件配置和应用场景更加多样化。以下是嵌入式系统中Bootloader被引导的一般流程: 1. 硬件复位 当嵌入式设备上电或复位时,处…...
【信息系统项目管理师-选择真题】2009下半年综合知识答案和详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 【第1~2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20题】【第21题】…...
TL494方案开关电源方案
TL494是德州仪器公司生产的一款固定频率脉宽调制(PWM)控制芯片,广泛应用于开关电源等电路中,以下是其相关方案介绍: 基本特性 双端输出:可提供推挽或单端两种输出模式。推挽模式下能驱动两个功率开关管交…...
RocketMQ事务消息是如何实现的?
大家好,我是锋哥。今天分享关于【RocketMQ事务消息是如何实现的?】面试题。希望对大家有帮助; RocketMQ事务消息是如何实现的? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 RocketMQ 事务消息的实现是通过 分布式事…...
16届蓝桥杯寒假刷题营】第2期DAY5IOI赛
3.小蓝小彬的代码挑战 - 蓝桥云课 问题描述 在蓝桥杯大赛中,小蓝和小彤是一对好朋友。他们在比赛中遇到了一个有趣的挑战。这个挑战是给定一个由大写字母组成的代码,他们需要找出这串代码中有多少个子序列LQB。小蓝和小彬都很聪明,他们想到…...
【云安全】云原生-K8S-搭建/安装/部署
一、准备3台虚拟机 务必保证3台是同样的操作系统! 1、我这里原有1台centos7,为了节省资源和效率,打算通过“创建链接克隆”2台出来 2、克隆之前,先看一下是否存在k8s相关组件,或者docker相关组件 3、卸载原有的docker …...
[A-29]ARMv8/v9-GIC-中断子系统的安全架构设计(Security/FIQ/IRQ)
ver0.1 前言 打开这篇文章的时候,我们已经为每一个中断信号规划一条路径,在外设和PE-Core之间建立了消息通道,外设有紧急的情况下可以给SOC中的大哥打报告了。下面就把接力棒就交到了CPU手里了,但是PE-Core要交给那个Exception Level以及Security下运行的软件处理呢?本文…...
12 款开源OCR发 PDF 识别框架
2024 年 12 款开源文档解析框架的选型对比评测:PDF解析、OCR识别功能解读、应用场景分析及优缺点比较 这是该系列的第二篇文章,聚焦于智能文档处理(特别是 PDF 解析)。无论是在模型预训练的数据收集阶段,还是基于 RAG…...
使用 lock4j-redis-template-spring-boot-starter 实现 Redis 分布式锁
在分布式系统中,多个服务实例可能同时访问和修改共享资源,从而导致数据不一致的问题。为了解决这个问题,分布式锁成为了关键技术之一。本文将介绍如何使用 lock4j-redis-template-spring-boot-starter 来实现 Redis 分布式锁,从而…...
css-background-color(transparent)
1.前言 在 CSS 中,background-color 属性用于设置元素的背景颜色。除了基本的颜色值(如 red、blue 等)和十六进制颜色值(如 #FF0000、#0000FF 等),还有一些特殊的属性值可以用来设置背景颜色。 2.backgrou…...
MySQL 9.2.0 的功能
MySQL 9.2.0 的功能 MySQL 9.2.0 的功能新增、弃用和删除内容如下: 新增功能 权限新增12:引入了CREATE_SPATIAL_REFERENCE_SYSTEM权限,拥有该权限的用户可执行CREATE SPATIAL REFERENCE SYSTEM、CREATE OR REPLACE SPATIAL REFERENCE SYSTEM…...
编程题-最长的回文子串(中等)
题目: 给你一个字符串 s,找到 s 中最长的回文子串。 示例 1: 输入:s "babad" 输出:"bab" 解释:"aba" 同样是符合题意的答案。示例 2: 输入:s &…...
打破传统束缚:领略 Web3 独特魅力
在互联网发展的历程中,我们见证了Web1和Web2的变迁。Web1是静态信息的展示平台,Web2则引领了社交互动和内容创作的繁荣,而如今,Web3作为新时代的互联网架构,正逐渐展现出其独特的魅力,带领我们走向一个更加…...
linux系统中的 scp的使用方法
SCP(Secure Copy Protocol)是一种通过加密的方式在本地主机和远程主机之间安全地传输文件的协议。 它是基于SSH协议的扩展,允许用户在不同主机之间进行文件复制和传输,是Linux和Unix系统中常用的工具之一。 在嵌入式Linux软件的…...
RAG技术:通过向量检索增强模型理解与生成能力
网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…...
【现代深度学习技术】深度学习计算 | 参数管理
【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上,结合当代大数据和大算力的发展而发展出来的。深度学习最重…...
【Linux基础指令】第三期
近期更新的基础指令链接: 【Linux基础指令】第一期-CSDN博客 【Linux基础指令】第二期-CSDN博客 本期博客的主题依旧是 "基础指令" ;话不多说,正文开始。 一、Linux的指令 1.zip / unzip 功能:打包压缩 命令格式&…...
WPS数据分析000005
目录 一、数据录入技巧 二、一维表 三、填充柄 向下自动填充 自动填充选项 日期填充 星期自定义 自定义序列 1-10000序列 四、智能填充 五、数据有效性 出错警告 输入信息 下拉列表 六、记录单 七、导入数据 编辑 八、查找录入 会员功能 Xlookup函数 VL…...
UiAutomator的详细介绍
UIAutomator作为一种高效的测试框架,通过自动化手段显著提升了用户界面(UI)测试的效率与准确性。它不仅支持自动生成功能测试用例,还允许开发者在不同设备上执行这些测试,确保了应用程序的一致性和稳定性。 以下是对 …...
在虚拟机里运行frida-server以实现对虚拟机目标软件的监测和修改参数(一)
frida-server下载路径 我这里选择frida-server-16.6.6-android-x86_64 以root身份启动adb 或 直接在android studio中打开 adb root 如果使用android studio打开的话,最好选择google api的虚拟机,默认以root模式开启 跳转到下载的frida-server文件位…...
Ubuntu二进制部署K8S 1.29.2
本机说明 本版本非高可用,单Master,以及一个Node 新装的 ubuntu 22.04k8s 1.29.3使用该文档请使用批量替换 192.168.44.141这个IP,其余照着复制粘贴就可以成功需要手动 设置一个 固定DNS,我这里设置的是 8.8.8.8不然coredns无法…...
机器学习周报-文献阅读
文章目录 摘要Abstract 1 相关知识1.1 WDN建模1.2 掩码操作(Masking Operation) 2 论文内容2.1 WDN信息的数据处理2.2 使用所收集的数据构造模型2.2.1 Gated graph neural network2.2.2 Masking operation2.2.3 Training loss2.2.4 Evaluation metrics 2…...
TensorFlow实现逻辑回归模型
逻辑回归是一种经典的分类算法,广泛应用于二分类问题。本文将介绍如何使用TensorFlow框架实现逻辑回归模型,并通过动态绘制决策边界和损失曲线来直观地观察模型的训练过程。 数据准备 首先,我们准备两类数据点,分别表示两个不同…...
06-AD向导自动创建P封装(以STM32-LQFP48格式为例)
自动向导创建封装 自动向导创建封装STM32-LQFP48Pin封装1.选则4排-LCC或者QUAD格式2.计算焊盘相定位长度3.设置默认引脚位置(芯片逆时针)4.特殊情况下:加额外的标记 其他问题测量距离:Ctrl M测量 && Ctrl C清除如何区分一脚和其他脚?芯片引脚是逆时针看的? 自动向导…...
《 C++ 点滴漫谈: 二十四 》深入 C++ 变量与类型的世界:高性能编程的根基
摘要 本文深入探讨了 C 中变量与类型的方方面面,包括变量的基本概念、基本与复合数据类型、动态类型与内存管理、类型推导与模板支持,以及类型系统的高级特性。通过全面的理论讲解与实际案例分析,展示了 C 类型系统的强大灵活性与实践价值。…...
Ceph:关于Ceph 中 RADOS 块设备快照克隆管理的一些笔记整理(12)
写在前面 准备考试,整理 ceph 相关笔记博文内容涉及使用 RADOS 块设备提供 RDB 的快照和克隆如何操作理解不足小伙伴帮忙指正对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的,是人的逃避方式,是对大众理想…...
C语言连接Mysql
目录 C语言连接Mysql下载 mysql 开发库 方法介绍mysql_init()mysql_real_connect()mysql_query()mysql_store_result()mysql_num_fields()mysql_fetch_fields()mysql_fetch_row()mysql_free_result()mysql_close() 完整代码 C语言连接Mysql 下载 mysql 开发库 方法一…...
2023CISCN初赛unzip
2023CISCN初赛unzip 随便上传一个文件,会自动跳转到uplaod.php目录下,源码如下: <?php error_reporting(0); highlight_file(__FILE__);$finfo finfo_open(FILEINFO_MIME_TYPE); if (finfo_file($finfo, $_FILES["file"]["tmp_name…...
Elasticsearch的索引生命周期管理
目录 零、参考一、ILM的基本概念二、ILM的实践步骤Elasticsearch ILM策略中的“最小年龄”是如何计算的?如何监控和调整Elasticsearch ILM策略的性能? 1. **监控性能**使用/_cat/thread_pool API基本请求格式请求特定线程池的信息响应内容 2. **调整ILM策…...
检测到联想鼠标自动调出运行窗口,鼠标自己作为键盘操作
联想鼠标会自动时不时的调用“运行”窗口 然后鼠标自己作为键盘输入 然后打开这个网页 (不是点击了什么鼠标外加按键,这个鼠标除了左右和中间滚轮,没有其他按键了)...
2024年记 | 凛冬将至
放弃幻想,准备斗争! 考研or就业? 上大学以来,考研上名校在我的心里一直是一颗种子,2024年初,当时的想法是考研和就业两手抓。买了张宇的高数现代,想要死磕! 也记了挺多笔记... 如果…...
【Java-数据结构】Java 链表面试题下 “最后一公里”:解决复杂链表问题的致胜法宝
我的个人主页 我的专栏:Java-数据结构,希望能帮助到大家!!!点赞❤ 收藏❤ 引言: Java链表,看似简单的链式结构,却蕴含着诸多有趣的特性与奥秘,等待我们去挖掘。它就像一…...
vim如何解决‘’文件非法关闭后,遗留交换文件‘’的问题
过程描述: 由于我修改文件时(一定得修改了文件,不做任何修改不会产生这个问题)的非法关闭,比如直接关闭虚拟机,或者直接断开远程工具的远程连接,产生了以下遗留交换文件的问题: 点击…...
国内优秀的FPGA设计公司主要分布在哪些城市?
近年来,国内FPGA行业发展迅速,随着5G通信、人工智能、大数据等新兴技术的崛起,FPGA设计企业的需求也迎来了爆发式增长。很多技术人才在求职时都会考虑城市的行业分布和发展潜力。因此,国内优秀的FPGA设计公司主要分布在哪些城市&a…...
运用python爬虫爬取汽车网站图片并下载,几个汽车网站的示例参考
当然,以下是一些常见的汽车网站及其爬虫示例代码,展示如何爬取汽车图片并下载。请注意,爬取网站内容时应遵守网站的使用协议和法律法规,避免对网站造成不必要的负担。 示例1:爬取汽车之家图片 网站地址 汽车之家 爬…...
IO进程寒假作业DAY6
请使用互斥锁 和 信号量分别实现5个线程之间的同步 使用互斥锁 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <stdio.h> #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> #include &…...
C++ 中用于控制输出格式的操纵符——setw 、setfill、setprecision、fixed
目录 四种操纵符简要介绍 setprecision基本用法 setfill的基本用法 fixed的基本用法 setw基本用法 以下是一些常见的用法和示例: 1. 设置字段宽度和填充字符 2. 设置字段宽度和对齐方式 3. 设置字段宽度和精度 4. 设置字段宽度和填充字符,结合…...
solidity高阶 -- 线性继承
Solidity是一种面向合约的高级编程语言,用于编写智能合约。在Solidity中,多线继承是一个强大的特性,允许合约从多个父合约继承属性和方法。本文将详细介绍Solidity中的多线继承,并通过不同的实例展示其使用方法和注意事项。 在Sol…...
PydanticAI应用实战
PydanticAI 是一个 Python Agent 框架,旨在简化使用生成式 AI 构建生产级应用程序的过程。 它由 Pydantic 团队构建,该团队也开发了 Pydantic —— 一个在许多 Python LLM 生态系统中广泛使用的验证库。PydanticAI 的目标是为生成式 AI 应用开发带来类似 FastAPI 的体验,它基…...
Leecode刷题C语言之跳跃游戏②
执行结果:通过 执行用时和内存消耗如下: int jump(int* nums, int numsSize) {int position numsSize - 1;int steps 0;while (position > 0) {for (int i 0; i < position; i) {if (i nums[i] > position) {position i;steps;break;}}}return steps…...
fpga学习入门 串口rs232回环
奇偶检验位这里是省略了 做好回环后可以使用上位机做回环测试,top文件写的方式就是将rx(fpga端)接受到的模块(pc端)tx发送出去,这两个端口用杜邦线连接,同理模块的rx连接fpga的tx,…...
单片机基础模块学习——DS18B20温度传感器芯片
不知道该往哪走的时候,就往前走。 一、DS18B20芯片原理图 该芯片共有三个引脚,分别为 GND——接地引脚DQ——数据通信引脚VDD——正电源 数据通信用到的是1-Wier协议 优点:占用端口少,电路设计方便 同时该协议要求通过上拉电阻…...
C基础寒假练习(4)
输入带空格的字符串,求单词个数、 #include <stdio.h> // 计算字符串长度的函数 size_t my_strlen(const char *str) {size_t len 0;while (str[len] ! \0) {len;}return len; }int main() {char str[100];printf("请输入一个字符串: ");fgets(…...
es6.7.1分词器ik插件安装-和head插件连接es特殊配置
es6.7.1分词器ik插件安装-和head插件连接es特殊配置 如果对运维课程感兴趣,可以在b站上、A站或csdn上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频 1.查看es6.7.1和es-head安装位置和es插件路径 [ro…...
Luzmo 专为SaaS公司设计的嵌入式数据分析平台
Luzmo 是一款嵌入式数据分析平台,专为 SaaS 公司设计,旨在通过直观的可视化和快速开发流程简化数据驱动决策。以下是关于 Luzmo 的详细介绍: 1. 背景与定位 Luzmo 前身为 Cumul.io ,专注于为 SaaS 公司提供嵌入式分析解决方案。…...