NET 5.0独立Azure函数未激发代码-超时



引用这些指令:

创建函数

功能-单网-5

独立功能

官方-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 blobn 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隔离调试--详细

你可以在VS中通过右键单击项目来做到这一点>属性>调试>Application Arguments,并将此命令粘贴到那里(或者,在命令行中,cd到函数项目中,然后运行相同的命令,再加上命令开头的关键字func(。

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

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

  3. 返回VS,点击Ctrl+Alt+p附加到进程(搜索dotnet以筛选出其他机器进程(

在此之后,您将立即看到函数反应,表示它已附加到进程。现在您可以调试了。这将阻止函数在本地计算机上超时,并在函数执行路径中需要的任何断点处停止。干杯=(

最新更新