![GCP StackDriver: Como correlacionar (e aninhar) logs de informações com logs de rastreamento?](https://rvso.com/image/1606675/GCP%20StackDriver%3A%20Como%20correlacionar%20(e%20aninhar)%20logs%20de%20informa%C3%A7%C3%B5es%20com%20logs%20de%20rastreamento%3F.png)
Por favor me ajudem, estou sem sucesso há 3 dias :/
Estou implantando vários serviços no Google Cloud Run e gostaria de rastrear solicitações e correlacionar registros a essas solicitações à medida que elas passam pelos serviços. O StackDriver possui uma ótima plataforma para isso no "StackDriver Trace". Estou usando a biblioteca Google.Cloud.Diagnostics em minhas APIs principais do asp.net. Consigo rastrear solicitações, iniciar intervalos e ver os intervalos aninhados dentro do rastreamento no StackDriver Trace Timeline. No entanto, não sei como fazer com que meus logs se correlacionem com os rastreamentos e extensões.
Os documentos do StackDriver afirmam que a gravação de "campos especiais" no LogEntry
objeto será reconhecida pela API Logging.
Diz especificamente o seguinte sobre o trace
campo:
The value of this field should be formatted as projects/[PROJECT-ID]/traces/[TRACE-ID], so it can be used by the Logs Viewer and the Trace Viewer to group log entries and display them in line with traces.
fonte:https://cloud.google.com/logging/docs/agent/configuration#special-fields
Tentei muitas coisas diferentes em meu JSON estruturado, mas o Stackdriver Trace View não reconhece meus registros e os anilha dentro do rastreamento de solicitação. Atualmente estou incluindo o trace e o spanId no JSON.
Aqui está um dos meus registros de que o StackDriver Trace não aninhará no trace:
{
insertId: "5da6c3a200j0923bx23x2"
jsonPayload: {
ConnectionId: "0HLQI121N94JM"
CorrelationId: null
RequestId: "0HLQI121N94JM:00000001"
RequestPath: "/graphql"
message: "Getting Collection of type: FakeItem in GetCollectionOfItemsAsync"
messageTemplate: "Getting Collection of type: FakeItem in GetCollectionOfItemsAsync"
spanId: "4560986706170855936"
timestamp: "2019-10-16T07:15:46.8713740Z"
trace: "projects/myProject/traces/04b4a840df0289bb9fddcd62235d3ee4"
}
labels: {
instanceId: "00bf4bf02d34e072dc1c49x8dj943x4b5609mubm0409u566ad08acf6283d2b5135651fd8f2633e7b06e7dde4b96cfddbf5373a642da0b65fb21cf87a5aad"
}
logName: "projects/myProject/logs/run.googleapis.com%2Fstdout"
receiveTimestamp: "2019-10-16T07:15:47.113845061Z"
resource: {
labels: {
configuration_name: "baseproject-graphql"
location: "us-central1"
project_id: "myProject"
revision_name: "baseproject-graphql-vhglp"
service_name: "baseproject-graphql"
}
type: "cloud_run_revision"
}
timestamp: "2019-10-16T07:15:46.871489Z"
}
Aqui está um log gerado pelo gcp que é reconhecido:
{
httpRequest: {
latency: "0.026068056s"
protocol: "HTTP/1.1"
remoteIp: "73.158.189.48"
requestMethod: "POST"
requestSize: "1950"
requestUrl: "https://baseproject-api.myUrl.com/graphql"
responseSize: "2768"
serverIp: "152.289.4.125"
status: 200
userAgent: "PostmanRuntime/7.18.0"
}
insertId: "5da6c3a8j90kjo9db8346"
labels: {
instanceId: "00bf4bf02d34e072dc1cfda1073f2f5ec6888d75e1d75f26259006ad08acf6283d2b5135651fd8f26398n9hu0h9h09gm08g76f67f567fb21cf87a5aad"
}
logName: "projects/myProject/logs/run.googleapis.com%2Frequests"
receiveTimestamp: "2019-10-16T07:15:47.207098181Z"
resource: {
labels: {
configuration_name: "baseproject-graphql"
location: "us-central1"
project_id: "myProject"
revision_name: "baseproject-graphql-vhglp"
service_name: "baseproject-graphql"
}
type: "cloud_run_revision"
}
severity: "INFO"
timestamp: "2019-10-16T07:15:46.877387Z"
trace: "projects/myProject/traces/04b4a840df0289bb9fddcd62235d3ee4"
}
Alguma ideia???