1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
|
# -------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License in the project root for
# license information.
# --------------------------------------------------------------------------
import logging
from urllib import request
from azure.monitor.opentelemetry import configure_azure_monitor
from opentelemetry import trace
logger = logging.getLogger(__name__)
# Configure Azure monitor collection telemetry pipeline
configure_azure_monitor()
tracer = trace.get_tracer(__name__)
with tracer.start_as_current_span("Request parent span") as span:
try:
# Requests made using the urllib library will be automatically captured
req = request.Request("https://www.example.org/", method="GET")
r = request.urlopen(req)
logger.warning("Request sent")
except Exception as ex:
# If an exception occurs, this can be manually recorded on the parent span
span.set_attribute("status", "exception")
span.record_exception(ex)
input()
|