Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
GET /v1/db/restore
LocalFileInfo 提供有关启动恢复过程的用户本地机器上的文件的信息,以便向其他用户提供有关正在进行的恢复过程的信息。
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
路径 |
字符串 |
文件的完整路径。 |
|||
字节大小 |
字符串 |
文件大小(以字节为单位)。如果未知,则为 0。 |
int64 |
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
代码 |
整数 |
int32 |
|||
消息 |
字符串 |
||||
细节 |
ProtobufAny 列表 |
Any
包含任意序列化的协议缓冲区消息以及描述序列化消息类型的 URL。
Protobuf 库提供支持,以实用程序函数或 Any 类型的附加生成方法的形式打包/解包 Any 值。
示例 1:在 C++ 中打包和解包消息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:在 Java 中打包和解包消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
Protobuf 库提供的 pack 方法默认使用“type.googleapis.com/full.type.name”作为类型 URL,而 unpack 方法仅使用类型 URL 中最后一个“/”后的完全限定类型名称,例如“foo.bar.com/x/y.z”将产生类型名称“y.z”。
Any
值的 JSON 表示使用反序列化、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。示例
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入的消息类型是众所周知的并且具有自定义 JSON 表示,则该表示将被嵌入,并添加一个字段value
,该字段除了@type
字段外还包含自定义 JSON。示例(对于消息[google.protobuf.Duration][])
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type |
字符串 |
一个 URL/资源名称,唯一标识序列化协议缓冲区消息的类型。此字符串必须包含至少一个“/”字符。URL 路径的最后一个段必须表示类型的完全限定名称(如 |
数据库导出清单描述了恢复请求的文件内容。为防止数据丢失,清单始终被解释为具有约束力,即服务器必须确保它将读取并使用清单中列出的每个文件,否则必须拒绝请求。
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
files |
恢复正文中的单个文件。
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
name |
字符串 |
文件名。这可能是也可能不是(相对)文件路径,由服务器解释。对于导出为 ZIP 文件的数据库,这是相对于存档根目录的路径。 |
|||
encoding |
UNKNOWN,UNCOMPREESSED,DEFLATED, |
||||
encodedSize |
字符串 |
int64 |
|||
decodedSize |
字符串 |
int64 |
|||
decodedCrc32 |
Long |
解码数据的 CRC32(IEEE)校验和。 |
int64 |
正在进行的或已完成的恢复过程的元数据。这是**静态**元数据,不会更改(即它不是状态)。
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
id |
字符串 |
标识恢复过程的 ID。自动分配。 |
|||
header |
|||||
startTime |
Date |
启动恢复过程的时间。 |
date-time |
||
initiatingUserName |
字符串 |
启动数据库恢复过程的用户。 |
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
metadata |
|||||
attemptId |
字符串 |
||||
state |
UNKNOWN,NOT_STARTED,IN_PROGRESS,PAUSED,COMPLETED, |
||||
resumeInfo |
|||||
error |
字符串 |
||||
bytesRead |
字符串 |
int64 |
|||
filesProcessed |
字符串 |
int64 |
COMPLETED:如果 error 为空则成功,否则失败
枚举值 |
---|
UNKNOWN |
NOT_STARTED |
IN_PROGRESS |
PAUSED |
COMPLETED |