Невозможно обновить развертывание GCP с помощью Java SDK менеджера развертывания - PullRequest
0 голосов
/ 14 апреля 2020

Я пытаюсь написать приложение для управления развертываниями GCP, используя Deployment Manager SDK для Java. Я могу вывести список развертываний успешно, но не могу обновить развертывание, поскольку SDK выдает исключение, показанное ниже.

com.google.api.client.googleapis.json.GoogleJsonResponseException: 404 Not Found
{
  "code" : 404,
  "errors" : [ {
    "domain" : "global",
    "message" : "The object 'projects/--redacted-project--/global/deployments' is not found.",
    "reason" : "notFound"
  } ],
  "message" : "The object 'projects/--redacted-project--/global/deployments' is not found."
}
        at com.google.api.client.googleapis.json.GoogleJsonResponseException.from(GoogleJsonResponseException.java:150)
        at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:113)
        at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:40)
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest$1.interceptResponse(AbstractGoogleClientRequest.java:321)
        at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:1067)
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:419)
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:352)
        at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:469)

Мой код вызова:

val content = new Deployment().setTarget(target)

val updateResult = client.deployments().update(project, name, content)
          .setCreatePolicy("CREATE_OR_ACQUIRE")
          .setDeletePolicy("DELETE")
          .setPreview(false)
          .execute()

Когда я включаю отладка для SDK Я вижу следующий обмен:

2020-04-13 17:52:36,353 [deploy-akka.deploy-dispatcher-10] INFO  c.g.a.c.h.HttpTransport - -------------- REQUEST  --------------
PUT https://www.googleapis.com/deploymentmanager/v2/projects/--redacted-project--/global/deployments/--redacted-deployment--
Accept-Encoding: gzip
Authorization: <Not Logged>
User-Agent: Google-API-Java-Client Google-HTTP-Java-Client/1.25.0 (gzip)
Content-Type: application/json; charset=UTF-8
Content-Encoding: gzip
Content-Length: 565

2020-04-13 17:52:36,353 [deploy-akka.deploy-dispatcher-10] INFO  c.g.a.c.h.HttpTransport - curl -v --compressed -X PUT -H 'Accept-Encoding: gzip' -H 'Authorization: <Not Logged>' -H 'User-Agent: Google-API-Java-Client Google-HTTP-Java-Client/1.25.0 (gzip)' -H 'Content-Type: application/json; charset=UTF-8' -H 'Content-Encoding: gzip' -d '@-' -- 'https://www.googleapis.com/deploymentmanager/v2/projects/--redacted-project--/global/deployments/--redacted-deployment--' << $$$

2020-04-13 17:52:36,354 [deploy-akka.deploy-dispatcher-10] INFO  c.g.a.c.h.HttpTransport - Total: 1,449 bytes

2020-04-13 17:52:36,354 [deploy-akka.deploy-dispatcher-10] INFO  c.g.a.c.h.HttpTransport - {"target":{"config":{"content":"imports:\n  - path: dep.jinja\n\nresources:\n  - name: testing\n    type: dep.jinja\n    properties:\n      env: prod\n      banana: yes\n      retentionInDays: 5"},"imports":[{"content":"resources:\n- name: riffraff-dataset\n  type: bigquery.v2.dataset\n  properties:\n    location: europe-west2\n    datasetReference:\n      datasetId: riffraff_test\n- name: test-table\n  type: bigquery.v2.table\n  metadata:\n    dependsOn:\n    - riffraff-dataset\n  properties:\n    datasetId: riffraff_test\n    tableReference:\n      tableId: banana\n    schema:\n      fields:\n        - name: species\n          type: string\n        - name: plantation\n          type: string\n        - name: harvested\n          type: date\n        - name: quantity\n          type: numeric\n        - name: edible\n          type: boolean\n{% if properties['banana'] == \"yes\" %}\n- name: test-topic\n  type: gcp-types/pubsub-v1:projects.topics\n  properties:\n    topic: riffraff-topic\n{% endif %}\n- name: riffraff-bucket\n  type: storage.v1.bucket\n  properties:\n    location: europe-west2\n    storageClass: STANDARD\n    iamConfiguration:\n      uniformBucketLevelAccess:\n        enabled: True\n    {% if properties['retentionInDays'] %}\n    lifecycle:\n      rule:\n        - action:\n            type: Delete\n          condition:\n            age: {{ properties['retentionInDays'] }}\n    {% endif %}","name":"dep.jinja"}]}}

2020-04-13 17:52:37,174 [deploy-akka.deploy-dispatcher-10] INFO  c.g.a.c.h.HttpTransport - -------------- RESPONSE --------------
HTTP/1.1 404 Not Found
Content-Type: application/json; charset=UTF-8
Vary: Origin
Vary: X-Origin
Vary: Referer
Content-Encoding: gzip
Date: Mon, 13 Apr 2020 16:52:37 GMT
Server: ESF
Cache-Control: private
X-XSS-Protection: 0
X-Frame-Options: SAMEORIGIN
X-Content-Type-Options: nosniff
Alt-Svc: quic=":443"; ma=2592000; v="46,43",h3-Q050=":443"; ma=2592000,h3-Q049=":443"; ma=2592000,h3-Q048=":443"; ma=2592000,h3-Q046=":443"; ma=2592000,h3-Q043=":443"; ma=2592000,h3-T050=":443"; ma=2592000
Transfer-Encoding: chunked

Так что это выглядит как недопустимый URL или объект.

Однако, если я использую инструмент CLI gcloud, чтобы сделать то же самое с --log-http, я вижу, что он достигает точно такой же конечной точки, но не получает 404:

==== request start ====
uri: https://www.googleapis.com/deploymentmanager/v2/projects/--redacted-project--/global/deployments/--redacted-deployment--?alt=json&preview=False&createPolicy=CREATE_OR_ACQUIRE&deletePolicy=DELETE
method: PUT

Не уверен куда go отсюда.

1 Ответ

0 голосов
/ 14 апреля 2020

После дальнейшего копания я заметил, что поля в теле JSON в запросе PUT были разными. gcloud CLI отправлял fingerprint, name и target, в то время как Java SDK отправлял только target.

Спрятан в документации для тела запроса он говорит, что вам нужно установить fingerprint для update и несколько других методов.

Сначала я изменил свой код, чтобы ПОЛУЧИТЬ развертывание и включил fingerprint в запрос, и он начал на работу.

val content = new Deployment().setName(name).setFingerprint(fingerprint).setTarget(target)

val updateResult = client.deployments().update(project, name, content)
  .setCreatePolicy("CREATE_OR_ACQUIRE")
  .setDeletePolicy("DELETE")
  .setPreview(false)
  .execute()

На мой взгляд 404 является ошибкой для этого. Google должен возвращать 400, так как клиент не включает в запрос обязательное поле.

Кроме того, SDK выполняет большое количество проверок предусловий для обнаружения недействительных запросов, но не включает этот. Я открыл вопрос в Google, чтобы предложить это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...