为Azure函数(v3)绑定到BlobTrigger的RequestTelemetry添加自定义属性



我想为用c#编写的Azure函数(V3)生成的RequestTelemetry添加自定义属性。

多亏了这个StackOverflow帖子,我设法实现了这个函数与HttpTrigger绑定。

var requestTelemetry = req.HttpContext?.Features.Get<RequestTelemetry>();
requestTelemetry.Properties.Add("MyProp", "Some value");

然而,当我尝试用BlobTrigger绑定对另一个函数做同样的事情时,它变得令人困惑。第一个挑战是:

如何在使用的函数中获得当前的RequestTelemetryBlobTrigger绑定吗?

在带有HttpTrigger绑定的函数中,该函数被注入HttpRequest参数

public async Task<IActionResult> Upload(
[HttpTrigger(AuthorizationLevel.Anonymous, "get", "post", Route = "upload/{name}")] HttpRequest req,
string name,
ILogger log,
ExecutionContext context)
{  
...
}

所以我们可以使用HttpRequest获得当前的RequestTelemetry。但是,带BlobTrigger的函数呢:

[FunctionName("Create-Thumbnail")]
public async Task CreateThumbnail([BlobTrigger("input/{name}",  Source = BlobTriggerSource.EventGrid, Connection = "AzureWebJobsStorage")] Stream image,
IDictionary<string,string> metadata,
string name,
ExecutionContext context)
{ 
...
}

我尝试注入HttpRequest并使用与HttpTrigger函数相同的方式。但是没有成功。

经过几个小时的广泛研究,我找不到任何与这个问题相关的文档或帖子。

谁能提供一些提示吗?

使用blob触发器时没有http请求。您仍然可以将自定义属性添加到执行期间生成的遥测中,方法是这样设置属性:

// The current telemetry item gets a property. 
// Useful if the function is not triggered by an http request
Activity.Current.AddTag("setUsingTag", "setUsingTag");
// Subsequent telemetry gets this property attached
Activity.Current.AddBaggage("setUsingActivityBaggage", "setUsingActivityBaggage"); 

当使用包袱而不是标签时,自定义属性被添加到执行期间生成的所有遥测中,如依赖调用等。

参见这个github线程。它还提到可能在以后的AI版本中引入一个错误,可能会迫使你降级AI以使其工作。


多亏了这个GitHub问题,在将System.Diagnostics.DiagnosticSource降级到4.6版本后,这终于可以工作了

<PackageReference Include="System.Diagnostics.DiagnosticSource" Version="4.6.0" />

最新更新