Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
GET /v1/discovered-clusters
ListDiscoveredClusters 返回根据请求字段过滤后的已发现集群列表。
名称 | 描述 | 必填 | 默认值 | 模式 |
---|---|---|---|---|
pagination.limit |
- |
null |
||
pagination.offset |
- |
null |
||
pagination.sortOption.field |
- |
null |
||
pagination.sortOption.reversed |
- |
null |
||
pagination.sortOption.aggregateBy.aggrFunc |
- |
UNSET |
||
pagination.sortOption.aggregateBy.distinct |
- |
null |
||
filter.names |
匹配特定名称的已发现集群。 |
- |
null |
|
filter.types |
匹配特定类型的已发现集群。 |
- |
null |
|
filter.statuses |
匹配特定状态的已发现集群。- STATUS_UNSPECIFIED:集群状态未知。如果安全集群缺少可能的匹配元数据,则可能会发生这种情况。- STATUS_SECURED:已发现的集群与安全集群匹配。- STATUS_UNSECURED:已发现的集群未与安全集群匹配。 |
- |
null |
|
filter.sourceIds |
匹配发现的特定云源 ID 集群。 |
- |
null |
字段名称 | 必填 | 可为空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
代码 |
整数 |
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 库提供的打包方法默认使用“type.googleapis.com/full.type.name”作为类型 URL,解包方法仅使用类型 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 路径的最后一部分必须表示类型的完全限定名称(如 |
DiscoveredCluster 表示从云源发现的集群。
字段名称 | 必填 | 可为空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
ID |
字符串 |
从元组 (metadata.id, metadata.type, source.id) 确定性生成的 UUIDv5。 |
|||
元数据 |
|||||
状态 |
未指定状态、已保护状态、未保护状态 |
||||
来源 |
字段名称 | 必填 | 可为空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
ID |
字符串 |
表示集群在云提供商处注册的唯一 ID。对于已保护的集群,与 storage.ClusterMetadata.id 匹配。 |
|||
名称 |
字符串 |
表示集群在云提供商处注册的名称。对于已保护的集群,与 storage.ClusterMetadata.name 匹配。 |
|||
类型 |
未指定、AKS、ARO、EKS、GKE、OCP、OSD、ROSA |
||||
提供商类型 |
未指定提供程序类型、AWS 提供程序类型、GCP 提供程序类型、Azure 提供程序类型 |
||||
区域 |
字符串 |
云提供商报告的区域。 |
|||
首次发现时间 |
日期 |
云源首次发现集群的时间戳。 |
日期时间 |
未指定状态:集群的状态未知。如果已保护的集群缺少可能匹配的元数据,则可能会发生这种情况。
已保护状态:已发现的集群与已保护的集群匹配。
未保护状态:已发现的集群未与已保护的集群匹配。
枚举值 |
---|
未指定状态 |
已保护状态 |
未保护状态 |