【问题标题】:.NET 5.0 Isolated Azure Function not firing code - Timing Out.NET 5.0 隔离 Azure 函数未触发代码 - 超时
【发布时间】:2021-04-01 13:11:33
【问题描述】:

参考这些说明:

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));
}

然后启动(调试器确实附加了 OK):

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();
}

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

【问题讨论】:

  • 我在这里打开了一个问题:github.com/Azure/azure-functions-dotnet-worker/issues/378
  • 我遇到了类似的问题,并在链接的 github 中发表了评论。感谢您提供资源链接。几个小时后,我看到的是,VSCode 的体验非常棒。在 VS 中是可怕的、有限的和破碎的。我不想在我们的微服务开发中使用 VSCode,但是通过以下选择 VSCode 的工作很简单,而且很有效。 docs.microsoft.com/en-us/azure/azure-functions/…
  • 几周前我遇到了类似的问题,由于我们与 Function App 共享一些常见项目,我不得不中止将我的 API 应用程序转换到 .net 5。主要原因是将功能转换为孤立的过程。 docs.microsoft.com/en-us/azure/azure-functions/… 此外,您需要 VS 2019 v16.11 来构建生产就绪代码,并且 v16.11 仍处于预览模式,这面临@Corey 提到的问题
  • 为了调试 .net 5 隔离进程,我使用以下 PS:func start --dotnet-isolated-debug。取自here

标签: c# .net azure azure-functions .net-5


【解决方案1】:

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

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

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

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

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

  2. 接下来,您等待函数运行并在函数的控制台中显示进程 ID (PID)。复制那个。

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

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-03-26
    • 2020-09-08
    • 2020-07-03
    • 1970-01-01
    • 1970-01-01
    • 2021-08-31
    • 2021-05-28
    • 2019-10-14
    相关资源
    最近更新 更多