将Azure函数用于Python,将结构化日志记录到应用程序洞察力?

Azure Functions for python, structured logging to Application Insights?(将Azure函数用于Python,将结构化日志记录到应用程序洞察力?)
本文介绍了将Azure函数用于Python,将结构化日志记录到应用程序洞察力?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在Azure函数中使用Python(3.8)时,有没有办法将结构化日志发送到Application Insights?更具体地说,我正在尝试发送带有日志消息的自定义维度。我所能找到的关于日志的所有内容都是this非常简短的部分。

推荐答案

更新0127:

按this github issue求解。以下是示例代码:

# Change Instrumentation Key and Ingestion Endpoint before you run this function app

import logging

import azure.functions as func
from opencensus.ext.azure.log_exporter import AzureLogHandler

logger_opencensus = logging.getLogger('opencensus')
logger_opencensus.addHandler(
    AzureLogHandler(
        connection_string='InstrumentationKey=aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee;IngestionEndpoint=https://eastus-6.in.applicationinsights.azure.com/'
    )
)

def main(req: func.HttpRequest) -> func.HttpResponse:
    properties = {
        'custom_dimensions': {
            'key_1': 'value_1',
            'key_2': 'value_2'
        }
    }

    logger_opencensus.info('logger_opencensus.info Custom Dimension', extra=properties)
    logger_opencensus.info('logger_opencensus.info Statement')
    return func.HttpResponse("OK")

请尝试OpenCensus Python SDK。

示例代码位于Logs部分,第5步:

说明:您还可以使用custom_dimensions字段在Extra关键字参数中向日志消息添加自定义属性。这些属性在Azure监视器的CustomDimensions中显示为键-值对。

样本

import logging

from opencensus.ext.azure.log_exporter import AzureLogHandler

logger = logging.getLogger(__name__)
# TODO: replace the all-zero GUID with your instrumentation key.
logger.addHandler(AzureLogHandler(
    connection_string='InstrumentationKey=00000000-0000-0000-0000-000000000000')
)

properties = {'custom_dimensions': {'key_1': 'value_1', 'key_2': 'value_2'}}

# Use properties in logging statements
logger.warning('action', extra=properties)

这篇关于将Azure函数用于Python,将结构化日志记录到应用程序洞察力?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)