Журналы Cloudwatch Действие PutLogEvents завершается неудачно с com.amazon.coral.service # UnknownOperationException при вызове из API-шлюза - PullRequest
0 голосов
/ 19 апреля 2019

Я использую тип интеграции Сервиса API шлюза AWS для добавления журналов в сервис Cloudwatch Logs с помощью действия PutLogEvents, как описано здесь: https://docs.aws.amazon.com/AmazonCloudWatchLogs/latest/APIReference/API_PutLogEvents.html

Я успешно настроил метод аналогичного типа длядобавьте элементы в таблицу DynamoDB с помощью действия PutItem, и это сработало просто отлично, поэтому я не уверен, что мне не хватает этого.

Я дважды проверил наличие опечаток и проблем с моим шаблоном.Успешно использовали PutLogEvents с помощью инструментов CLI, поэтому установка кажется все в порядке.

Вот несколько скриншотов моей настройки из панели инструментов AWS:

enter image description here

Вот шаблон сопоставления, который я использую:

{
  "logGroupName": "FromAPI",
  "logStreamName": "$input.path('$.streamName')",
  "logEvents": [
    {
      "timestamp": $input.path('$.ts'), 
      "message": "$input.path('$.message')"
    }
  ]
}

Ответ, который я получаю, имеет код состояния 200, но следующее тело ответа:

{
  "Output": {
    "__type": "com.amazon.coral.service#UnknownOperationException",
    "message": null
  },
  "Version": "1.0"
}

Вот отредактированный (xxx) журнал выполнения:

Execution log for request xxx
Fri Apr 19 02:28:58 UTC 2019 : Starting execution for request: xxx
Fri Apr 19 02:28:58 UTC 2019 : HTTP Method: POST, Resource Path: /log
Fri Apr 19 02:28:58 UTC 2019 : Method request path: {}
Fri Apr 19 02:28:58 UTC 2019 : Method request query string: {}
Fri Apr 19 02:28:58 UTC 2019 : Method request headers: {}
Fri Apr 19 02:28:58 UTC 2019 : Method request body before transformations: {
    "streamName": "12345",
    "ts": 1555641510000,
    "message": "help!"
}
Fri Apr 19 02:28:58 UTC 2019 : Endpoint request URI: https://logs.xxx.amazonaws.com/?Action=PutLogEvents
Fri Apr 19 02:28:58 UTC 2019 : Endpoint request headers: {Authorization=xxx, X-Amz-Date=20190419T022858Z, x-amzn-apigateway-api-id=xxx, Accept=application/json, User-Agent=AmazonAPIGateway_xxx, X-Amz-Security-Token=xxx [TRUNCATED]
Fri Apr 19 02:28:58 UTC 2019 : Endpoint request body after transformations: {
  "logGroupName": "FromAPI",
  "logStreamName": "12345",
  "logEvents": [
    {
      "timestamp": 1555641510000, 
      "message": "help!"
    }
  ]
}
Fri Apr 19 02:28:58 UTC 2019 : Sending request to https://logs.xxx.amazonaws.com/?Action=PutLogEvents
Fri Apr 19 02:28:58 UTC 2019 : Received response. Status: 200, Integration latency: 38 ms
Fri Apr 19 02:28:58 UTC 2019 : Endpoint response headers: {x-amzn-RequestId=xxx, Content-Type=application/json, Content-Length=105, Date=Fri, 19 Apr 2019 02:28:58 GMT}
Fri Apr 19 02:28:58 UTC 2019 : Endpoint response body before transformations: {"Output":{"__type":"com.amazon.coral.service#UnknownOperationException","message":null},"Version":"1.0"}
Fri Apr 19 02:28:58 UTC 2019 : Method response body after transformations: {"Output":{"__type":"com.amazon.coral.service#UnknownOperationException","message":null},"Version":"1.0"}
Fri Apr 19 02:28:58 UTC 2019 : Method response headers: {X-Amzn-Trace-Id=Root=xxx, Content-Type=application/json}
Fri Apr 19 02:28:58 UTC 2019 : Successfully completed execution
Fri Apr 19 02:28:58 UTC 2019 : Method completed with status: 200

В мой поток Cloudwatch Logs ничего не регистрируется - тело ответа на запрос интеграции API-шлюза содержит ошибку UnknownOperationException.

Лучше всего предположить, что этот запрос по какой-то причине не связан с действием PutLogEvents.Странно, что в этом случае код состояния равен 200Есть идеи?

1 Ответ

0 голосов
/ 19 апреля 2019

Это должно работать, если вы добавите следующие строки в верхней части шаблона отображения:

#set($context.requestOverride.header['X-Amz-Target'] = "Logs_20140328.PutLogEvents")
#set($context.requestOverride.header['Content-Type'] = "application/x-amz-json-1.1")

Это очень сложно и плохо документировано.Вы можете найти эти заголовки в примере запроса для PutLogEvents .

...