我正在尝试将数据从一个GCP项目中的数据存储复制到另一个项目-该过程似乎没有出现任何错误,但是也没有填充我的目标数据存储。
在我的源项目中,创建一个存储桶,并将其数据存储如下导出:
gcloud datastore export gs://ctb_datatransfer
然后我切换到目标项目并运行
gcloud datastore import gs://ctb_datatransfer/2020-03-01T18:41:37_32872/2020-03-01T18:41:37_32872.overall_export_metadata
这些步骤似乎都没有指示任何错误,但是导入完成后,我的目标数据存储仍然为空。
非常感谢收到任何帮助,因为我对所发生的事情并不十分了解-我相信我已经授予了存储桶正确的权限(如果没有的话,将会看到某种权限失败。我猜是)
导出步骤的输出看起来像这样
done: true
metadata:
"@type": type.googleapis.com/google.datastore.admin.v1.ExportEntitiesMetadata
common:
endTime: "2020-03-01T18:41:50.349159Z"
operationType: EXPORT_ENTITIES
startTime: "2020-03-01T18:41:37.188012Z"
state: SUCCESSFUL
entityFilter: {}
outputUrlPrefix: gs://ctb_datatransfer/2020-03-01T18:41:37_32872
progressBytes:
workCompleted: "8848"
workEstimated: "6480"
progressEntities:
workCompleted: "40"
workEstimated: "40"
name: projects/chattyappsdata-staging/operations/ASAzMTEwMzAzMTMJGnRsdWFmZWQHEjJ3LXVlLXNib2otbmltZGEQCigS
response:
"@type": type.googleapis.com/google.datastore.admin.v1.ExportEntitiesResponse
虽然导入步骤的输出看起来像这样
done: true
metadata:
"@type": type.googleapis.com/google.datastore.admin.v1.ImportEntitiesMetadata
common:
endTime: "2020-03-01T18:46:25.251008Z"
operationType: IMPORT_ENTITIES
startTime: "2020-03-01T18:45:44.029056Z"
state: SUCCESSFUL
entityFilter: {}
inputUrl: gs://ctb_datatransfer/2020-03-01T18:41:37_32872/2020-03-01T18:41:37_32872.overall_export_metadata
progressBytes:
workCompleted: "8110"
workEstimated: "8848"
progressEntities:
workCompleted: "40"
workEstimated: "40"
name: projects/chattytoolbox/operations/AiAwNTEwNDAxMTMJGnRsdWFmZWQHEjJ3LXVlLXNib2otbmltZGEQCigS
response:
"@type": type.googleapis.com/google.protobuf.Empty
如OP在评论中所述,整个过程最终得以完成,只是几个小时后才完成。这是一个可能的解释:
查看有关导入实体的文档,我发现导入是long running operation(LRO),因此可能需要大量时间才能完成。从您共享的导入输出中,我们可以看到操作did finish,但我相信它缺少某些传播,该传播已随着时间而固定。
此外,导入命令(gcloud datastore import
)仅启动LRO。如果指定参数--async
,该命令将立即返回,但如果未指定,它将等待响应。在--async
的gcloud选项卡上,指出即使导入命令被取消,操作也将继续,从而加强了有关命令,导入和传播的独立性的理论。