如何通过 GCP 部署管理器创建网络端点组

byg*_*ace 3 google-cloud-platform google-deployment-manager

我正在尝试使用 Google Cloud 部署管理器为我的 App Engine 负载均衡器创建网络端点组。我找不到它的现有资源类型,因此我尝试使用自定义类型提供程序 ( deploymentmanager.v2beta.typeProvider)。我面临的主要问题是我想创建一个,networkEndpointType: SERVERLESS但 API 仅支持区域性。

这是API:https://cloud.google.com/compute/docs/reference/rest/beta/networkEndpointGroups/insert

这是部署管理器脚本:

resources:
- name: network-endpoint-group
  type: deploymentmanager.v2beta.typeProvider
  properties:
    descriptorUrl: https://www.googleapis.com/discovery/v1/apis/compute/v1/rest
    options:
      inputMappings:
      - fieldName: name
        location: PATH
        methodMatch: ^(GET|DELETE|PUT|POST)$
        value: $.resource.properties.name
      - fieldName: Authorization
        location: HEADER
        value: >
          $.concat("Bearer ", $.googleOauth2AccessToken())

- name: neg_create
  action: {{ env["project"] }}/network-endpoint-group:compute.networkEndpointGroups.insert
  properties:
    name: my-network-endpoint-group
    project: {{ env["project"] }}
    zone: us-east1-b
    appEngine:
      service: my-service
    networkEndpointType: SERVERLESS
  metadata:
    runtimePolicy:
    - CREATE
    dependsOn:
    - network-endpoint-group
Run Code Online (Sandbox Code Playgroud)

如果我按照上面的方式运行它,那么我会得到:

SERVERLESS 类型的网络端点仅在区域中允许

如果我删除该zone属性,那么我会得到:

对象缺少必需的属性([“zone”])

我还没有找到太多关于如何通过部署管理器创建它们或如何通过 API 创建区域 NEG 的文档。

有人可以提供有关如何通过 GCP 部署管理器创建网络端点组的指导,或者提供有关为什么不支持它的参考吗?

byg*_*ace 5

我感觉自己像个傻瓜,因为使用了错误的 API。显然,存在一组区域端点。我会删除这个问题,但由于普遍缺乏关于如何做此类事情的文档,我将保留它。

这是我需要使用的API: https://cloud.google.com/compute/docs/reference/rest/beta/regionNetworkEndpointGroups/insert

这就是部署管理器中的样子:

resources:
- name: network-endpoint-group
  type: deploymentmanager.v2beta.typeProvider
  properties:
    descriptorUrl: https://www.googleapis.com/discovery/v1/apis/compute/v1/rest
    options:
      inputMappings:
      - fieldName: name
        location: PATH
        methodMatch: ^(GET|DELETE|PUT|POST)$
        value: $.resource.properties.name
      - fieldName: Authorization
        location: HEADER
        value: >
          $.concat("Bearer ", $.googleOauth2AccessToken())

- name: neg_create
  action: {{ env["project"] }}/network-endpoint-group:compute.regionNetworkEndpointGroups.insert
  properties:
    name: my-network-endpoint-group
    project: {{ env["project"] }}
    region: us-east1
    appEngine:
      service: my-service
    networkEndpointType: SERVERLESS
  metadata:
    runtimePolicy:
    - CREATE
    dependsOn:
    - network-endpoint-group
Run Code Online (Sandbox Code Playgroud)