Com nosso agente de linguagem Go, você pode obter o logs in context, que permite ver o registro do seu aplicativo no contexto de outros dados New Relic . Para informações gerais sobre este recurso, consulte logs contextualizados APM.
Modificações nas opções de configuração do agente Go são necessárias para utilizar o seguinte recurso logs contextualizados.
Para a maioria dos usuários, usar o encaminhamento automático de logs embutido no agente Go é a melhor solução. É fácil de configurar e funciona muito bem para a maioria dos casos de uso.
Usando esta opção, seus logs incluem span.id, trace.id, hostname, entity.guid e entity.name. Esses atributos vinculam seus logs a intervalos, rastreamentos e outras telemetrias, facilitando a solução de problemas. Saiba mais sobre as limitações de encaminhamento de logs.
O encaminhamento automático de log do aplicativo agora está habilitado por padrão no agente Go versão 3.20.0 ou mais alto. Se o seu aplicativo usa essas versões do agente Go, você não precisa alterar suas opções de configuração para ativar o encaminhamento automático de logs.
Se estiver usando uma versão mais antiga do agente Go, você precisará modificar sua configuração para ativar o encaminhamento de log do aplicativo:
app, err := newrelic.NewApplication(
newrelic.ConfigAppLogForwardingEnabled(true),
)
Para usuários com necessidades de registro mais personalizadas, ou usuários que desejam enviar mais de 10.000 registros por ciclo de 60 segundos, ou 833 registros por ciclo de 5 segundos, para a New Relic, recomendamos que você configure manualmente o encaminhamento de registros. Depois de configurar o encaminhador de logs para enviar logs ao New Relic, modifique a configuração do agente Go para enriquecer seus logs. Enriquecer os logs significa que o retirar de logs adiciona os dados de contexto APM , incluindo span.id, trace.id, hostname, entity.guid e entity.name, ao log:
app, err := newrelic.NewApplication(
newrelic.ConfigAppLogDecoratingEnabled(true),
)
Se você estiver usando o agente Go versão v3.20.0 ou superior, será necessário desabilitar o encaminhamento de log do aplicativo para evitar a duplicação do log coletado pelo New Relic.
app, err := newrelic.NewApplication(
newrelic.ConfigAppLogDecoratingEnabled(true),
newrelic.ConfigAppLogForwardingEnabled(false),
)
Instalando um plug-in de contexto de login
Depois que seu agente estiver configurado para enviar log para New Relic, instale um plug-in de logs contextualizados para instrumentar sua biblioteca de log.
A biblioteca logWriter é um io.Writer que integra automaticamente o recurso New Relic Logs in Context mais recente ao agente da biblioteca padrão go. Siga estas etapas para instalá-lo em seu aplicativo. Esta biblioteca requer que a versão instalada do agente Go seja 3.19.1 ou superior.
Adicione o pacote logWriter ao seu módulo.
bash
$
go get github.com/newrelic/go-agent/v3/integrations/logcontext-v2/logWriter
Importe o pacote logWriter no arquivo onde você inicializa seu agente.
Crie um objeto logWriter. Deve ser passado um io.Writer válido, onde será gravado o log, e um aplicativo go-agente inicializado. O exemplo a seguir grava na saída padrão.
writer := logWriter.New(os.Stdout, newRelicApp)
Crie um objeto agente com seu novo objeto logWriter como destino de saída do agente.
Neste ponto, qualquer log gravado com o agente criado será tratado pelo go-agente com base nas configurações de registro.
Transação
Caso queira capturar o contexto de uma transação, um novo objeto logWriter e um novo objeto agente deverão ser criados. Para criar um novo objeto logWriter para sua transação, use as funções WithTransaction() ou WithContext() dependendo de como a transação é passada para sua função. Estas funções farão uma nova cópia do objeto logWriter original com o contexto da transação incluído.
Se sua função receber um contexto encapsulado em uma transação, use a função WithContext():
txnWriter := writer.WithContext(myWrappedContext)
Se sua função receber um ponteiro de transação, use a função WithTransaction():
Certifique-se de sempre criar um novo agente com um novo logWriter para cada transação. Isso evita a possibilidade de processos assíncronos acessarem o mesmo objeto agente com informações contextuais diferentes.
A ferramenta logWriter foi projetada para falhar silenciosamente. Para ativar informações de depuração, chame o método DebugLogging(true) no objeto logWriter. Quando ocorre um erro no logWriter, ele sempre imprimirá sua linha de log não editada na primeira linha. Quando o DebugLogging estiver habilitado, ele imprimirá uma mensagem de erro na linha seguinte se ocorrer um erro.
writer.DebugLogging(true)
A biblioteca zerologWriter é um io.Writer que integra automaticamente o recurso mais recente New Relic Logs in Context no zerolog. Siga estas etapas para instalá-lo em seu aplicativo. Esta biblioteca requer que a versão instalada do go-agente seja 3.19.1 ou superior.
Adicione o pacote zerologWriter ao seu módulo.
bash
$
go get github.com/newrelic/go-agent/v3/integrations/logcontext-v2/zerologWriter
Importe o pacote zerologWriter no arquivo onde você inicializa seu agente zerolog.
Crie um objeto zerologWriter. Deve ser passado um io.Writer válido, onde será gravado o log, e um aplicativo go-agente inicializado. O exemplo a seguir grava na saída padrão.
writer := logWriter.New(os.Stdout, newRelicApp)
Crie um objeto agente com seu novo objeto zerologWriter como destino de saída do agente.
logger := zerolog.New(writer)
Neste ponto, qualquer log gravado com o agente criado será tratado pelo go-agente com base nas configurações de registro.
Transação
Caso queira capturar o contexto de uma transação, um novo objeto zerologWriter e um novo objeto agente deverão ser criados. Para criar um novo objeto zerologWriter para sua transação, use as funções WithTransaction() ou WithContext() dependendo de como a transação é passada para sua função. Essas funções farão uma nova cópia do objeto zerologWriter original com o contexto da transação incluído.
Se sua função receber um contexto encapsulado em uma transação, use a função WithContext():
txnWriter := writer.WithContext(myWrappedContext)
Se sua função receber um ponteiro de transação, use a função WithTransaction():
Certifique-se de sempre criar um novo agente com um novo zerologWriter para cada transação. Isso evita a possibilidade de processos assíncronos acessarem o mesmo objeto agente com informações contextuais diferentes.
txnLogger := logger.Output(txnWriter)
Resolução de problemas
A ferramenta zerologWriter foi projetada para falhar silenciosamente. Para ativar informações de depuração, chame o método DebugLogging(true) no objeto zerologWriter. Quando ocorre um erro no zerologWriter, ele sempre imprimirá sua linha de log não editada na primeira linha. Quando o DebugLogging estiver habilitado, ele imprimirá uma mensagem de erro na linha seguinte se ocorrer um erro.
writer.DebugLogging(true)
O plug-in nrlogrus permite o logs contextualizados automático na ingestão com a framework de logging logrus. Depois que seu aplicativo estiver configurado para usá-lo, o agente Go irá ingerir automaticamente qualquer log escrito em logrus. Isso requer o agente Go versão 3.18.0 ou superior.
Adicione o pacote nrlogrus ao seu módulo.
bash
$
go get github.com/newrelic/go-agent/v3/integrations/logcontext-v2/nrlogrus
Importe o pacote nrlogrus no arquivo onde você inicializa seu agente logrus.
Configure e crie um novo formatador nrlogrus. Deve ser passado um aplicativo válido e qualquer formatador logrus válido. O formatador passado determinará a aparência do log que será gravado.
Defina o formatador do seu agente para o formatador nrlogrus recém-criado.
log := logrus.New()
log.SetFormatter(nrlogrusFormatter)
Neste ponto, qualquer log gravado com o agente criado será tratado pelo go-agente com base nas configurações de registro.
Transação
Ao logar instrumentado dentro de uma transação, você deve passar essa transação para logrus como um contexto. Isso criará um novo objeto agente para aquela transação que vincula o log tratado pelo agente à transação e aos períodos em que ocorreu.
Se você tiver um contexto que contém uma transação:
txnLogger := log.WithContext(yourWrappedContext)
Caso contrário, você pode criar um contexto e passá-lo para o logrus:
O plug-in nrzap permite o logs contextualizados automático na ingestão com a framework de log Zap. Assim que seu aplicativo estiver configurado para utilizá-lo, o go-agente irá ingerir automaticamente qualquer log escrito no Zap. Isso requer que a versão instalada do go-agente seja 3.22.1 ou superior.
Adicione o pacote nrzap ao seu módulo.
bash
$
go get github.com/newrelic/go-agent/v3/integrations/logcontext-v2/nrzap
Importe o pacote nrzap no arquivo onde você inicializa seu agente Zap.
Configure e crie um novo objeto central Zap para o log do seu aplicativo. Como o objeto principal nunca precisa ser alterado e apenas precisa ser empacotado, é uma boa prática manter um ponteiro para esse objeto disponível para que você possa reutilizá-lo para criar núcleos Zap empacotados com mais eficiência.
Enrole o objeto central Zap para capturar e enviar log para New Relic. Observe que, desde que a função wrap receba um núcleo Zap válido, o núcleo que ela retorna será válido, mesmo se um erro for retornado. Por esse motivo, é importante verificar o tipo de erro.
O plug-in nrslog permite o logs contextualizados automático na ingestão com a framework padrão da biblioteca slog. Depois que seu aplicativo estiver configurado para usá-lo, o agente Go irá ingerir automaticamente qualquer log gravado com seu agente de slog empacotado. Isso requer o agente Go versão 3.30.0 ou superior.
Adicione o pacote nrslog ao seu módulo.
bash
$
go get github.com/newrelic/go-agent/v3/integrations/logcontext-v2/nrslog
Importe o pacote nrslog no arquivo onde você inicializa seu agente slog.
Configure e crie um novo manipulador nrslog. Deve ser passado um ponteiro de aplicativo New Relilc válido, um io.Writer e um ponteiro para um objeto slog.HandlerOptions. Funções de conveniência são empacotadas no nrslog para instrumentar automaticamente os manipuladores de texto e json que saem da caixa no slog. Neste exemplo, agruparemos slog.TextHandler.
Crie um novo agente com seu manipulador instrumentado.
logger := slog.New(instrumentedTextHandler)
Neste ponto, qualquer log gravado com este novo agente será tratado pelo go-agente com base nas configurações de log.
Transação
Ao instrumentar logs dentro de uma transação, você deve passar essa transação para nrslog. A maneira preferida de fazer isso é passando-o dentro de um contexto para o slog. Se você tiver um contexto que contém uma transação:
Seu registro pode incluir informações confidenciais protegidas pela HIPAA ou outros protocolos de conformidade. Por padrão, ofuscamos padrões numéricos que parecem ser de itens como cartões de crédito ou números de Seguro Social, mas pode ser necessário aplicar hash ou mascarar informações adicionais.
Para mais informações, veja nossa documentação sobre expressão de ofuscação e regras. Você pode aplicar hash ou mascarar seus dados log usando a interface New Relic ou NerdGraph, nossa API GraphQL.
Qual é o próximo?
Depois de configurar o logs contextualizados, aproveite ao máximo seus dados de registro:
Veja seu logs contextualizados do desempenho do seu aplicativo na interfaceAPM . Solucione erros com distributed tracing, rastreamento de pilha, registro de aplicativo e muito mais.
Obtenha visibilidade mais profunda do seu aplicativo e dos dados de desempenho da plataforma encaminhando seu log com nosso agente de infraestrutura. Revise seu log de infraestrutura na interface.