本文档介绍了如何创建、更新、查看和删除 Pub/Sub 主题。本文档还介绍了如何为主题和订阅命名。
主题中的数据复制
Pub/Sub 主题使用三个可用区来存储数据。该服务保证至少两个可用区的同步复制,并尽最大努力复制到另一个第三方可用区。Pub/Sub 复制操作仅在一个区域内。
主题的属性
创建或更新主题时,必须指定其属性。
添加默认订阅。向 Pub/Sub 主题添加默认订阅。创建主题后,您可以为该主题再创建一个订阅。默认订阅具有以下属性:
-sub
的订阅 ID- 拉取传送类型
- 邮件保留期限为 7 天
- 闲置 31 天后过期
- 确认时限为 10 秒
- 立即重试政策
架构。架构是消息数据字段必须遵循的格式。架构是 Pub/Sub 强制执行发布者与订阅者之间的合约。主题架构有助于实现消息类型和权限标准化,以允许组织中的不同团队使用它们。Pub/Sub 会为消息类型和权限创建集中管理中心。如需创建具有架构的主题,请参阅创建和管理架构。
消息保留时长:指定 Pub/Sub 主题在发布后保留多长时间。消息保留期结束后,无论其确认状态如何,Pub/Sub 都可能会舍弃消息。您需要为存储到该主题的所有消息支付消息存储费用。
- 默认 = 未启用
- 最小值 = 10 分钟
- 最大值 = 31 天
使用客户管理的加密密钥 (CMEK)。指定主题是否使用 CMEK 加密。默认情况下,Pub/Sub 使用 Google 管理的密钥加密消息。如果您指定此选项,Pub/Sub 会将信封加密模式与 CMEK 结合使用。在此方法中,Cloud KMS 不会加密消息。相反,Cloud KMS 会对 Pub/Sub 为每个主题创建的数据加密密钥 (DEK) 进行加密。Pub/Sub 使用为主题生成的最新 DEK 来加密消息。Pub/Sub 会在消息传送给订阅者之前不久对其进行解密。如需详细了解如何创建密钥,请参阅配置消息加密。
主题、订阅或快照的命名准则
Pub/Sub 资源名称用于唯一标识 Pub/Sub 资源,例如主题、订阅或快照。资源名称必须符合以下格式:
projects/project-identifier/collection/ID
project-identifier
:必须是可在 Google Cloud 控制台中获取的项目 ID。例如my-cool-project
。collection
:必须是topics
、subscriptions
或snapshots
中的一个。ID
:必须符合以下准则:- 不以字符串
goog
开头 - 以字母开头
- 包含 3 到 255 个字符
- 只能包含以下字符:字母
[A-Za-z]
、数字[0-9]
、短划线-
、下划线_
、英文句号.
、波浪线~
、加号+
和百分号%
您可以在不带网址编码的资源名称中使用上述列表中的特殊字符。不过,在网址中使用其他特殊字符时,请务必确保这些字符能够正确编码或解码。例如,
mi-tópico
是无效的 ID。不过,mi-t%C3%B3pico
是有效的。此格式在您进行 REST 调用时至关重要。- 不以字符串
创建主题
请先创建主题,然后才能发布或订阅。
控制台
如需创建主题,请按以下步骤操作:
在 Google Cloud 控制台中,转到 Pub/Sub 主题页面。
点击创建主题。
在主题 ID 字段中,输入主题 ID。
保留添加默认订阅选项。
请勿选择其他选项。
点击创建主题。
gcloud CLI
如需创建主题,请运行 gcloud pubsub topics create
命令:
gcloud pubsub topics create TOPIC_ID
REST
如需创建主题,请使用 projects.topics.create
方法:
必须使用 Authorization
标头中的访问令牌对请求进行身份验证。如需获取当前应用默认凭据的访问令牌,请运行以下命令:gcloud auth application-default print-access-token
。
PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID Authorization: Bearer ACCESS_TOKEN
其中:
响应:
{ "name": "projects/PROJECT_ID/topics/TOPIC_ID" }
C++
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C++ 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C++ API 参考文档。
C#
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C# 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C# API 参考文档。
Go
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Go 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Go API 参考文档。
Java
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Java 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Java API 参考文档。
Node.js
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Node.js 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Node.js API 参考文档。
PHP
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 PHP 设置说明进行操作。如需了解详情,请参阅 Pub/Sub PHP API 参考文档。
Python
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Python 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Python API 参考文档。
Ruby
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Ruby 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Ruby API 参考文档。
组织政策限制条件
组织政策可以限制主题创建,例如,某项政策可以限制 Compute Engine 区域中的消息存储。为避免主题创建错误,请在创建主题之前根据需要检查和更新组织政策。
如果是新创建的项目,请等待几分钟,等待组织政策初始化,然后再创建主题。
使用架构创建主题
创建主题时,可能需要为其分配架构。
以下是关于使用架构的一些准则:
- 您无法向现有主题添加架构。
- 您只能在创建主题时指定架构。
- 架构与主题关联后,您便无法更新架构或移除其与该主题的关联。
- 您可以将同一架构应用于其他新主题。
- 如果您删除架构,则无法发布到所有关联的主题。
如需详细了解架构,请参阅创建和管理架构。
控制台
要创建主题并为其分配架构,请按照下列步骤操作:
在 Google Cloud 控制台中,转到 Pub/Sub 主题页面。
点击创建主题。
在主题 ID 字段中,输入主题 ID。
选中使用架构复选框。其他选项保留为默认设置。
点击选择 Pub/Sub 架构,然后选择创建新架构。如果要使用现有架构,请跳到第 7 步。
在架构 ID 字段中,输入架构的 ID。
对于架构类型,请选择 Avro 或协议缓冲区。
在架构定义字段中,为您的架构输入 Avro 或协议缓冲区定义。
点击创建以保存架构。
在创建主题对话窗口的选择 Pub/Sub 架构字段中,搜索您的架构。
点击创建以保存主题,并向其分配选定的架构。
gcloud
如需创建使用先前创建的架构分配的主题,请运行 gcloud pubsub topics create
命令:
gcloud pubsub topics create TOPIC_ID \ --message-encoding=ENCODING_TYPE \ --schema=SCHEMA_ID
其中:
- TOPIC_ID 是您正在创建的主题的 ID。
- ENCODING_TYPE 是针对架构验证的消息的编码。该值必须设置为
JSON
或BINARY
。 - SCHEMA_ID 是现有架构的 ID。
您也可以从其他 Google Cloud 项目分配架构:
gcloud pubsub topics create TOPIC_ID \ --message-encoding=ENCODING_TYPE \ --schema=SCHEMA_ID \ --schema-project=SCHEMA_PROJECT \ --project=TOPIC_PROJECT
其中:
- SCHEMA_PROJECT 是架构的 Google Cloud 项目的项目 ID。
- TOPIC_PROJECT 是主题的 Google Cloud 项目的项目 ID。
REST
如需创建主题,请使用 projects.topics.create
方法:
请求:
必须使用 Authorization
标头中的访问令牌对请求进行身份验证。如需获取当前应用默认凭据的访问令牌,请运行以下命令:gcloud auth application-default print-access-token
。
PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID Authorization: Bearer ACCESS_TOKEN
请求正文:
{ "schemaSettings": { "schema": "SCHEMA_NAME", "encoding": "ENCODING_TYPE" } }
其中:
- PROJECT_ID 是项目 ID。
- TOPIC_ID 是您的主题 ID。
- SCHEMA_NAME 是应该根据其验证发布消息的架构的名称。格式为
projects/PROJECT_ID/schemas/SCHEMA_ID
。 - ENCODING_TYPE 是根据架构验证过的消息的编码。其必须设置为
JSON
或BINARY
。
响应:
{ "name": "projects/PROJECT_ID/topics/TOPIC_ID", "schemaSettings": { "schema": "SCHEMA_NAME", "encoding": "ENCODING_TYPE" } }
C++
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 C++ 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C++ API 参考文档。
C#
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 C# 设置说明进行操作。 如需了解详情,请参阅 Pub/Sub C# API 参考文档。
Go
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 Go 设置说明进行操作。 如需了解详情,请参阅 Pub/Sub Go API 参考文档。
Java
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 Java 设置说明进行操作。 如需了解详情,请参阅 Pub/Sub Java API 参考文档。
Node.js
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 Node.js 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Node.js API 参考文档。
PHP
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 PHP 设置说明进行操作。如需了解详情,请参阅 Pub/Sub PHP API 参考文档。
Python
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 Python 设置说明进行操作。 如需了解详情,请参阅 Pub/Sub Python API 参考文档。
Ruby
在尝试此示例之前,请按照《快速入门:使用客户端库》中的 Ruby 设置说明进行操作。 如需了解详情,请参阅 Pub/Sub Ruby API 参考文档。
删除主题
删除主题后,其订阅不会被删除。订阅者可以通过订阅积压消息积压消息。在主题被删除后,其订阅的主题名称为 _deleted-topic_
。如果您尝试创建的主题与您刚刚删除的主题名称相同,可能在短期内会出现错误。
控制台
在 Google Cloud 控制台中,转到 Pub/Sub 主题页面。
选择一个主题,然后点击
更多操作。点击删除。
系统会显示删除主题窗口。
输入
delete
,然后点击删除。
gcloud CLI
如需删除主题,请使用 gcloud pubsub topics delete
命令:
gcloud pubsub topics delete TOPIC_ID
REST
如需删除主题,请使用 projects.topics.delete
方法:
请求:
必须使用 Authorization
标头中的访问令牌对请求进行身份验证。如需获取当前应用默认凭据的访问令牌,请运行以下命令:gcloud auth application-default print-access-token
。
DELETE https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID Authorization: Bearer ACCESS_TOKEN
其中:
响应:
如果请求成功,响应将为空的 JSON 对象。
C++
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C++ 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C++ API 参考文档。
C#
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C# 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C# API 参考文档。
Go
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Go 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Go API 参考文档。
Java
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Java 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Java API 参考文档。
Node.js
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Node.js 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Node.js API 参考文档。
PHP
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 PHP 设置说明进行操作。如需了解详情,请参阅 Pub/Sub PHP API 参考文档。
Python
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Python 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Python API 参考文档。
Ruby
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Ruby 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Ruby API 参考文档。
列出主题
控制台
在 Google Cloud 控制台中,转到 Pub/Sub 主题页面。
主题页面列出了所有可用的主题。
gcloud CLI
如需列出主题,请使用 gcloud pubsub topics list
命令:
gcloud pubsub topics list
REST
如需列出主题,请使用 projects.topics.list
方法:
请求:
必须使用 Authorization
标头中的访问令牌对请求进行身份验证。如需获取当前应用默认凭据的访问令牌,请运行以下命令:gcloud auth application-default print-access-token
。
GET https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics Authorization: Bearer ACCESS_TOKEN
其中:
响应:
{ "topics": [ { "name": "projects/PROJECT_ID/topics/mytopic1", ... }, { "name": "projects/PROJECT_ID/topics/mytopic2", ... } ] }
C++
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C++ 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C++ API 参考文档。
C#
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 C# 设置说明进行操作。如需了解详情,请参阅 Pub/Sub C# API 参考文档。
Go
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Go 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Go API 参考文档。
Java
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Java 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Java API 参考文档。
Node.js
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Node.js 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Node.js API 参考文档。
PHP
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 PHP 设置说明进行操作。如需了解详情,请参阅 Pub/Sub PHP API 参考文档。
Python
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Python 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Python API 参考文档。
Ruby
在尝试此示例之前,请按照使用客户端库的 Pub/Sub 快速入门中的 Ruby 设置说明进行操作。如需了解详情,请参阅 Pub/Sub Ruby API 参考文档。
默认情况下,每个查询最多返回 100 个结果。 您可以使用页面大小参数指定一个其他值(最高 1000)。
监控主题
您可以在 Pub/Sub 中监控主题。
后续步骤
为您的主题选择订阅类型。
为您的主题创建订阅。
使用 gcloud CLI 创建或修改主题。
使用 REST API 创建或修改主题。