Esta tradução de máquina é fornecida para sua comodidade.

Caso haja alguma divergência entre a versão em inglês e a traduzida, a versão em inglês prevalece. Acesse esta página para mais informações.

Criar um problema

insert_distributed_trace_headers (API do agente Python)

Sintaxe

newrelic.agent.insert_distributed_trace_headers(list_of_headers)

Este método é usado para inserir cabeçalhos usados para conectar transações dentro de um distributed trace.

Requisitos

Agente Python versão 5.6.0.135 ou superior.

distributed tracing deve estar ativado.

Descrição

Esta API requer quedistributed tracing esteja ativado.

Para obter instruções sobre como usar esta chamada, juntamente com sua chamada de parceiro accept_distributed_trace_headers, consulte Habilitar distributed tracing com API do agente.

Esta chamada é usada para implementar distributed tracing. Ele insere cabeçalhos em uma lista que pode ser lida pelo aplicativo receptor com o método accept_distributed_trace_headers .

Parâmetro

Parâmetro

Descrição

headers

list

Obrigatório. Uma lista de cabeçalhos. Esta lista será modificada pela chamada (os cabeçalhos serão inseridos na lista na forma de (header_name, header_value)).

Valores de retorno

Retorna None. A lista de entradas será atualizada por uma chamada a esta função.

Exemplos

Importante

Para manter a ordem adequada dos spans em um trace, você deve gerar a carga útil no contexto do span que a envia.

Crie uma carga distributed trace dentro de uma tarefa em segundo plano

Um exemplo de uso de insert_distributed_trace_headers na criação de um rastreamento externo a partir de uma única tarefa em segundo plano:

@newrelic.agent.background_task()
def main(url):
with newrelic.agent.ExternalTrace('my_external_library', url, method='GET'):
# Generate the payload in the context of the ExternalTrace
# span that sends it
headers = []
newrelic.agent.insert_distributed_trace_headers(headers)
response = my_external_library._get(url, headers=headers)
data = _process_response(response)

Crie uma carga distributed trace dentro de um traceexterno

Um exemplo de uso insert_distributed_trace_headers na criação de um rastreamento externo:

def _bind_url(url, *args, **kwargs):
# _bind_url is called with the args and kwargs sent to the `get`
# method below
return url
@newrelic.agent.external_trace('my_external_library', _bind_url, method='GET')
def get(url):
headers = []
newrelic.agent.insert_distributed_trace_headers(headers)
return my_external_library._get(url, headers=headers)