0

我想通过 java google-api-client 使用 InstanceTemplate 创建一个实例。执行操作后,新实例会显示在 GCP 的 Compute Engine 前端中,并已创建。10-15 秒后,实例消失。 GCP-Compute Engine 虚拟机-实例概览

按照参考手册,我无法理解为什么我的代码不起作用。
https://cloud.google.com/compute/docs/reference/rest/v1/instances/insert

Compute.Instances.Insert insert = compute
                    .instances()
                    .insert("{{project-id}}","europe-west1-c",instance)
                    .setSourceInstanceTemplate("/compute/v1/projects/{{project-id}}/global/instanceTemplates/instance-template-1")
                    .setZone("europe-west1-c")
                    .setProject("{{project-id}}");
            Operation op = insert.execute();

实例对象如下所示:

Instance instance = new Instance();
instance.setName(instanceName);
instance.setMachineType("zones/europe-west1-c/machineTypes/g1-small");

Gradle 依赖项

compile 'com.google.api-client:google-api-client:1.31.2'  
compile group: 'com.google.apis', name: 'google-api-services-compute', version: 'v1-rev235-1.25.0'

来自 GCP 的日志:

{
  "protoPayload": {
    "@type": "type.googleapis.com/google.cloud.audit.AuditLog",
    "status": {
      "code": 3,
      "message": "INVALID_PARAMETER"
    },
    "authenticationInfo": {
      "principalEmail": "compute-dev-me@{{project-id}}.iam.gserviceaccount.com"
    },
    "requestMetadata": {
      "callerIp": "12.34.56.78",
      "callerSuppliedUserAgent": "redacted/0.1 Google-API-Java-Client/1.31.2 Google-HTTP-Java-Client/1.37.0 (gzip),gzip(gfe)"
    },
    "serviceName": "compute.googleapis.com",
    "methodName": "v1.compute.instances.insert",
    "resourceName": "projects/{{project-id}}/zones/europe-west1-c/instances/test-mit-richtig",
    "request": {
      "@type": "type.googleapis.com/compute.instances.insert"
    }
  },
  "insertId": "-duwg4fde7a2",
  "resource": {
    "type": "gce_instance",
    "labels": {
      "instance_id": "redacted-number",
      "zone": "europe-west1-c",
      "project_id": "{{project-id}}"
    }
  },
  "timestamp": "2021-02-xxTxx:xx:xx.565227Z",
  "severity": "ERROR",
  "logName": "projects/{{project-id}}/logs/cloudaudit.googleapis.com%2Factivity",
  "operation": {
    "id": "operation-1613xxxx41-xxxxxxxx-xxxxxxxx-xxxxxxx",
    "producer": "compute.googleapis.com",
    "last": true
  },
  "receiveTimestamp": "2021-02-xxTxx:xx:xx.569578819Z"
}
4

1 回答 1

0

在查看提供的日志后,您会收到Invalid Parameter错误代码。在您的参数中,您将实例名称设置如下:

instance.setName(instanceName);

GCE 实例有一个命名约定,其中名称必须以小写字母开头,后跟一串字符或连字符,并且不能以连字符结尾。在您的情况下,您的代码中有一个大写的n(实例名称)。如下设置应该可以解决问题:

instance.setName(instancename);

我在您的日志中注意到的另一件事是项目 id 显示为{{project-id}},如果这还没有被您编辑(如果它有很好的做法,但您应该指定代码的编辑部分帮助理解日志)。

----- 评论后编辑 -----

检查 Google Cloud Platform 上的活动选项卡后,我们发现它是由服务帐户权限引起的。

在以下链接中,您可以找到有关创建和启用服务帐户的信息。

于 2021-02-12T10:01:20.450 回答