我想为用c#编写的Azure函数(V3)生成的RequestTelemetry添加自定义属性。
多亏了这个StackOverflow帖子,我设法实现了这个函数与HttpTrigger绑定。
var requestTelemetry = req.HttpContext?.Features.Get<RequestTelemetry>();
requestTelemetry.Properties.Add("MyProp", "Some value");
然而,当我尝试用BlobTrigger绑定对另一个函数做同样的事情时,它变得令人困惑。第一个挑战是:
如何在使用的函数中获得当前的
RequestTelemetry
BlobTrigger绑定吗?
在带有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" />