本页介绍了如何在 Vertex AI Agent Builder 中管理长时间运行的操作 (LRO) 的生命周期。
如果对某个方法的调用可能需要很长时间才能完成,系统就会返回长时间运行的操作对象。例如,当您通过 API 或客户端库调用 documents.import
时,Vertex AI Agent Builder API 会创建一个长时间运行的操作。该操作会跟踪处理作业的状态。
您可以使用 Vertex AI Agent Builder API 提供的长时间运行操作方法来检查操作的状态。您还可以列出或轮询操作。
在操作完成之后,操作的记录会保留大约 30 天,也就是说,在这段时间之后,您将无法再查看或列出操作。
获取长时间运行的操作的详细信息
以下示例展示了如何获取操作的详细信息。
REST
如需获取长时间运行的操作的状态并查看其详细信息,请按以下步骤操作:
您可以通过以下两种方式之一找到相应操作的名称:
调用返回长时间运行的操作的方法后,请查看响应。
例如,如果您调用
documents.import
,响应的开头将如下所示:{ "name": "projects/12345/locations/global/collections/default_collection/dataStores/my-datastore_4321/branches/0/operations/import-documents-56789", "metadata": { "@type": "type.googleapis.com/google.cloud.discoveryengine.v1beta.ImportDocumentsMetadata" } }
响应中的
name
值提供操作名称,可用于查询操作状态。复制操作名称时,请勿添加引号。通过列出长时间运行的操作来获取操作名称。
对创建操作的资源调用
operations.get
方法:curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://discoveryengine.googleapis.com/v1beta/OPERATION_NAME"
OPERATION_NAME:上一步中的操作名称。
GET
命令的响应前几行如下所示:{ "operations": [ { "name": "projects/12345/locations/global/collections/default_collection/dataStores/my-datastore_4321/branches/0/operations/import-documents-56789", "metadata": { "@type": "type.googleapis.com/google.cloud.discoveryengine.v1alpha.ImportDocumentsMetadata", } } ] }
Python
如需了解详情,请参阅 Vertex AI Agent Builder Python API 参考文档。
如需向 Vertex AI Agent Builder 进行身份验证,请设置应用默认凭据。 如需了解详情,请参阅为本地开发环境设置身份验证。
列出长时间运行的操作
以下示例展示了如何列出 Google Cloud 资源的操作。
REST
如需列出 Google Cloud 资源的长时间运行操作,请按以下步骤操作:
调用
operations.list
方法curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://discoveryengine.googleapis.com/v1beta/projects/PROJECT_ID/locations/global/collections/default_collection/dataStores/DATA_STORE_ID/operations"
DATA_STORE_ID:使用引擎创建的 Vertex AI Agent Builder 数据存储区的 ID。在 Google Cloud 控制台网址中,数据存储区 ID 位于
engines/
之后,/data
之前。
Python
如需了解详情,请参阅 Vertex AI Agent Builder Python API 参考文档。
如需向 Vertex AI Agent Builder 进行身份验证,请设置应用默认凭据。 如需了解详情,请参阅为本地开发环境设置身份验证。
轮询长时间运行的操作
以下示例展示了如何轮询操作的状态。
REST
如需轮询长时间运行的操作,直到其完成为止,请按以下步骤操作:
运行以下命令,该命令会重复调用
operations.get
方法,并在每次请求之间使用 10 秒的退避时间:while true; \ do curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://discoveryengine.googleapis.com/v1beta/OPERATION_NAME"; \ sleep 10; \ done
OPERATION_NAME:操作名称,请参阅获取长时间运行的操作的详细信息。例如:
projects/12345/locations/global/collections/default_collection/dataStores/my-datastore_4321/branches/0/operations/import-documents-56789
在状态显示
"done": true
后,停止轮询作业 (Control+Z
)。
Python
如需了解详情,请参阅 Vertex AI Agent Builder Python API 参考文档。
如需向 Vertex AI Agent Builder 进行身份验证,请设置应用默认凭据。 如需了解详情,请参阅为本地开发环境设置身份验证。