gpt4 book ai didi

c# - .NET 5.0 独立 Azure 函数未触发代码 - 超时

转载 作者:行者123 更新时间:2023-12-02 05:56:24 27 4
gpt4 key购买 nike

引用这些说明:

Creating-Functions

Function-Using-Net-5

Isolated-Functions

Official-2

我创建了一个 .NET 5.0 独立函数,最初一切正常。当我运行它时,它只是超时:

2021-04-01T12:16:43.912 [Information] Executing 'Functions.MediaUploadProcessorFunction' (Reason='New blob detected: uploads/32~Flowers.png', Id=729ad0ad-0668-4d88-84de-5c623f8a01c1)
2021-04-01T12:16:44.068 [Information] Trigger Details: MessageId: 759690bc-4ca7-4007-8084-ff1bf01de571, DequeueCount: 1, InsertionTime: 2021-04-01T12:16:42.000+00:00, BlobCreated: 2021-04-01T12:16:34.000+00:00, BlobLastModified: 2021-04-01T12:16:34.000+00:00
2021-04-01T12:21:19.917 [Information] Host Status: {"id": "myfunctionsdev","state": "Running","version": "3.0.15405.0","versionDetails": "3.0.15405 Commit hash: c696322564f1f9dc9557bfa495c0485ddf71eeef","platformVersion": "92.0.7.77","instanceId": "05815e0557966c201dc16275542526907206bb509874c0c62f71bc49fbcaa301","computerName": "RD281878F6217D","processUptime": 327992}275542526907206bb509874c0c62f71bc49fbcaa301","computerName": "RD281878F6217D","processUptime": 327992}tion' (Id: '729ad0ad-0668-4d88-84de-5c623f8a01c1'). Initiating cancellation.'Functions.MediaUploadProcessorFunction' (Id: '729ad0ad-0668-4d88-84de-5c623f8a01c1'). Initiating cancellation.4de-5c623f8a01c1, Duration=301517ms)Timeout value of 00:05:00 was exceeded by function: Functions.MediaUploadProcessorFunction, Duration=301517ms)Timeout value of 00:05:00 was exceeded by function: Functions.MediaUploadProcessorFunction
2021-04-01T12:21:46.469 [Warning] A function timeout has occurred. Restarting worker process executing invocationId '729ad0ad-0668-4d88-84de-5c623f8a01c1'.
2021-04-01T12:21:46.472 [Information] Restarting channel '6c9e4a92-c2d5-48c4-9474-7d3e70f7a6d4' that is executing invocation '729ad0ad-0668-4d88-84de-5c623f8

它检测到函数并触发触发器,但实际函数未运行(调试器未附加)。

[Function(nameof(MediaUploadProcessorFunction))]
public async Task Run([BlobTrigger(containerName + "/{name}", Connection = "AzureWebJobsStorage")] Stream myBlob, string name, ILogger log)
{
System.Diagnostics.Debugger.Launch();
System.Diagnostics.Debugger.Break();

log.LogInformation($"C# Blob trigger function Processed blob\n Name:{name} \n Size: {myBlob.Length} Bytes");
}

public MediaUploadProcessorFunction(IEmailService emailService, IMediaRepository mediaRepository, IOptions<ErrorEmailOptions> errorEmailOptions, IOptions<ValuesOptions> valuesOptions, IGroupRepository groupRepository)
{
System.Diagnostics.Debugger.Launch();
System.Diagnostics.Debugger.Break();

_emailService = emailService ?? throw new ArgumentNullException(nameof(emailService));
_mediaRepository = mediaRepository ?? throw new ArgumentNullException(nameof(mediaRepository));
_errorEmailOptions = errorEmailOptions?.Value ?? throw new ArgumentNullException(nameof(errorEmailOptions));
_values = valuesOptions?.Value ?? throw new ArgumentNullException(nameof(valuesOptions));
_groupRepository = groupRepository ?? throw new ArgumentNullException(nameof(groupRepository));
}

启动(调试器确实附加正常):

static Task Main(string[] args)
{
System.Diagnostics.Debugger.Launch();

var config = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("local.settings.json", optional: true, reloadOnChange: true)
.AddEnvironmentVariables()
.Build();

var host = new HostBuilder()
.ConfigureAppConfiguration(configurationBuilder =>
{
configurationBuilder.AddCommandLine(args);
})
.ConfigureFunctionsWorkerDefaults()
.ConfigureServices(services =>
{
services.AddLogging();

services.Configure<ValuesOptions>(config.GetSection("Values"));
services.AddScoped<IMediaRepository, MediaRepository>();
services.Configure<ErrorEmailOptions>(config.GetSection("ErrorEmail"));
services.AddScoped<IEmailService, EmailService>();
services.AddScoped<IGroupRepository, GroupRepository>();

services.AddDbContext<Context>(opts =>
{
var conn = config.GetConnectionString("Context");
opts.UseSqlServer(conn);
});
})
.Build();

return host.RunAsync();
}

有人有什么想法我可以尝试吗?

最佳答案

进程外意味着您的函数宿主和运行时运行在不同的进程中,因此您必须将调试器附加到进程中才能进行调试。

  1. 在 Visual Studio 中,使用在保存该函数的函数项目 csproj 的属性上设置的此参数来运行函数(这样做很方便,这样您就不必在以后的运行中重复该命令):

主机启动 --dotnet-isolated-debug --verbose

您可以在 VS 中执行此操作,方法是右键单击项目 > 属性 > 调试 > 应用程序参数,然后将此命令粘贴到此处(或者,在命令行中,cd 进入函数项目并运行相同的命令加上关键字命令开头的 func)。

  • 将函数项目作为启动项目运行。右键单击功能项目 > 设置为启动。然后使用 f5 或按开始

  • 接下来等待函数运行并在函数的控制台中显示进程 ID (PID)。复制该内容。

  • 返回 VS,点击 Ctrl + Alt + P 附加到进程(搜索dotnet以过滤掉其他机器进程)

  • 在此之后,您将立即看到该函数使用react,表示它附加到了一个进程。现在你可以调试了。这应该会阻止函数在本地计算机上超时,并在函数执行路径中所需的任何断点处停止。干杯=)

    关于c# - .NET 5.0 独立 Azure 函数未触发代码 - 超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66905189/

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com