Структура журнала Cloud Logging

Cloud Logging представляет журналы с использованием типа данных LogEntry , который определяет общие данные для всех записей журнала, а также конкретные полезные данные, которые могут включать облачные службы Google. Дополнительные сведения см. в разделе «Интеграция журналов LogEntry и Fleet Engine API» .

Длинные журналы делятся на несколько записей журнала. См. раздел «Обработка разделенных журналов» в этой документации.

Примеры записей журнала

В следующем примере показан LogEntry для журнала UpdateVehicle . Запрос и ответ RPC расположены внутри поля jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "request": {
          "header": {4},
          "updateMask": "deviceSettings",
          "vehicleId": "uniqueVehicleId",
          "vehicle": {2}
        },
        "response": {
          "name": "providers/example-project-id/vehicles/uniqueVehicleId",
          "availableCapacity": 2,
          "state": "VEHICLE_STATE_OFFLINE",
          "maximumCapacity": 2,
          "vehicleType": {1},
          "supportedTrips": {1}
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog"
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "labels": {2},
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Если возвращается ошибка RPC, поле responseVehicle очищается, а поле errorResponse устанавливается и заполняется в jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "errorResponse": {
          "httpStatusCode": 404,
          "code": "NOT_FOUND",
          "message": "No entity with id invalidVehicleId exists"
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog",
        "request": {
          "vehicle": {3},
          "updateMask": "deviceSettings",
          "vehicleId": "fakeVehicleId",
          "header": {4}
        }
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "severity": "ERROR",
      "labels": {2}
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Дополнительные сведения о языке запросов журналирования см. в разделе Язык запросов журналирования .

Информацию о том, как использовать журналы для создания метрик, см. в разделе Обзор метрик на основе журналов .

Что дальше

Обрабатывайте длинные записи журнала с помощью разделенных журналов .

,

Cloud Logging представляет журналы с использованием типа данных LogEntry , который определяет общие данные для всех записей журнала, а также конкретные полезные данные, которые могут включать облачные службы Google. Дополнительные сведения см. в разделе «Интеграция журналов LogEntry и Fleet Engine API» .

Длинные журналы делятся на несколько записей журнала. См. раздел «Обработка разделенных журналов» в этой документации.

Примеры записей журнала

В следующем примере показан LogEntry для журнала UpdateVehicle . Запрос и ответ RPC расположены внутри поля jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "request": {
          "header": {4},
          "updateMask": "deviceSettings",
          "vehicleId": "uniqueVehicleId",
          "vehicle": {2}
        },
        "response": {
          "name": "providers/example-project-id/vehicles/uniqueVehicleId",
          "availableCapacity": 2,
          "state": "VEHICLE_STATE_OFFLINE",
          "maximumCapacity": 2,
          "vehicleType": {1},
          "supportedTrips": {1}
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog"
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "labels": {2},
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Если возвращается ошибка RPC, поле responseVehicle очищается, а поле errorResponse устанавливается и заполняется в jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "errorResponse": {
          "httpStatusCode": 404,
          "code": "NOT_FOUND",
          "message": "No entity with id invalidVehicleId exists"
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog",
        "request": {
          "vehicle": {3},
          "updateMask": "deviceSettings",
          "vehicleId": "fakeVehicleId",
          "header": {4}
        }
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "severity": "ERROR",
      "labels": {2}
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Дополнительные сведения о языке запросов журналирования см. в разделе Язык запросов журналирования .

Информацию о том, как использовать журналы для создания метрик, см. в разделе Обзор метрик на основе журналов .

Что дальше

Обрабатывайте длинные записи журнала с помощью разделенных журналов .

,

Cloud Logging представляет журналы с использованием типа данных LogEntry , который определяет общие данные для всех записей журнала, а также конкретные полезные данные, которые могут включать облачные службы Google. Дополнительные сведения см. в разделе «Интеграция журналов LogEntry и Fleet Engine API» .

Длинные журналы делятся на несколько записей журнала. См. раздел «Обработка разделенных журналов» в этой документации.

Примеры записей журнала

В следующем примере показан LogEntry для журнала UpdateVehicle . Запрос и ответ RPC расположены внутри поля jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "request": {
          "header": {4},
          "updateMask": "deviceSettings",
          "vehicleId": "uniqueVehicleId",
          "vehicle": {2}
        },
        "response": {
          "name": "providers/example-project-id/vehicles/uniqueVehicleId",
          "availableCapacity": 2,
          "state": "VEHICLE_STATE_OFFLINE",
          "maximumCapacity": 2,
          "vehicleType": {1},
          "supportedTrips": {1}
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog"
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "labels": {2},
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Если возвращается ошибка RPC, поле responseVehicle очищается, а поле errorResponse устанавливается и заполняется в jsonPayload .

    {
      "insertId": "c6b85fbc927343fc8a85338c57a65733",
      "jsonPayload": {
        "errorResponse": {
          "httpStatusCode": 404,
          "code": "NOT_FOUND",
          "message": "No entity with id invalidVehicleId exists"
        },
        "@type": "type.googleapis.com/maps.fleetengine.v1.UpdateVehicleLog",
        "request": {
          "vehicle": {3},
          "updateMask": "deviceSettings",
          "vehicleId": "fakeVehicleId",
          "header": {4}
        }
      },
      "resource": {
        "type": "fleetengine.googleapis.com/Fleet",
        "labels": {2}
      },
      "timestamp": "2021-01-01T00:00:00.000000000Z",
      "severity": "ERROR",
      "labels": {2}
      "logName": "projects/example-project-id/logs/fleetengine.googleapis.com%2Fupdate_vehicle",
      "receiveTimestamp": "2021-01-01T00:00:00.000000000Z"
    }

Дополнительные сведения о языке запросов журналирования см. в разделе Язык запросов журналирования .

Информацию о том, как использовать журналы для создания метрик, см. в разделе Обзор метрик на основе журналов .

Что дальше

Обрабатывайте длинные записи журнала с помощью разделенных журналов .