VS2022 社区版在调试模式下运行 Azure Function 应用程序时定期挂起

问题描述 投票:0回答:1

我有一个现有的 Azure 函数应用程序,在隔离进程模式下使用 .Net 8。我已经在 VS2022 Enterprise 中使用它几个月了。在一台新笔记本电脑上,我有 VS2022 社区版。在调试模式下启动应用程序时,它会在启动过程中频繁挂起。详细模式已打开,挂起前显示的最后一行是“读取函数元数据(Worker)”。

我发现清洗溶液没有影响。删除bin文件夹并重建可能可以正常启动。删除 bin 文件夹并重新启动 VS2022 几乎总能使其正常启动。停止调试会话并重新启动会导致循环再次开始。

在另一台机器上的 VS2022 Enterprise 中从未出现过该问题。在 JetBrains Rider 中运行相同的解决方案没有任何问题。

关于原因和解决方法有什么想法吗?

Launch window

azure-functions visual-studio-2022 .net-8.0
1个回答
0
投票

您的 Visual Studio 2022 社区版正在尝试读取函数元数据以查找项目内的函数触发器。

尝试从以下位置卸载 Azure Functions 核心工具:- C\Users\AppData\Local zure-functions-core-toolsC\Program Files\Microsoft\Azure Functions Core Tools 然后从此链接再次安装最新版本的 Azure Functions Core 工具。

另外,检查您的

host.json
文件是否正确并存在于您的 Function 应用程序项目中:-

{
    "version": "2.0",
    "logging": {
        "applicationInsights": {
            "samplingSettings": {
                "isEnabled": true,
                "excludedTypes": "Request"
            },
            "enableLiveMetricsFilters": true
        }
    }
}

我的 .net 8.0 HttpTrigger 隔离函数代码:-

using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.Functions.Worker;
using Microsoft.Extensions.Logging;

namespace FunctionApp12
{
    public class Function1
    {
        private readonly ILogger<Function1> _logger;

        public Function1(ILogger<Function1> logger)
        {
            _logger = logger;
        }

        [Function("Function1")]
        public IActionResult Run([HttpTrigger(AuthorizationLevel.Function, "get", "post")] HttpRequest req)
        {
            _logger.LogInformation("C# HTTP trigger function processed a request.");
            return new OkObjectResult("Welcome to Azure Functions!");
        }
    }
}

输出:-

enter image description here

我的功能应用程序

csproj
:-

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <TargetFramework>net8.0</TargetFramework>
    <AzureFunctionsVersion>v4</AzureFunctionsVersion>
    <OutputType>Exe</OutputType>
    <ImplicitUsings>enable</ImplicitUsings>
    <Nullable>enable</Nullable>
  </PropertyGroup>
  <ItemGroup>
    <FrameworkReference Include="Microsoft.AspNetCore.App" />
    <PackageReference Include="Microsoft.Azure.Functions.Worker" Version="1.20.1" />
    <PackageReference Include="Microsoft.Azure.Functions.Worker.Extensions.Http" Version="3.1.0" />
    <PackageReference Include="Microsoft.Azure.Functions.Worker.Extensions.Http.AspNetCore" Version="1.2.0" />
    <PackageReference Include="Microsoft.Azure.Functions.Worker.Sdk" Version="1.16.4" />
    <PackageReference Include="Microsoft.ApplicationInsights.WorkerService" Version="2.21.0" />
    <PackageReference Include="Microsoft.Azure.Functions.Worker.ApplicationInsights" Version="1.1.0" />
  </ItemGroup>
  <ItemGroup>
    <None Update="host.json">
      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
    </None>
    <None Update="local.settings.json">
      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
      <CopyToPublishDirectory>Never</CopyToPublishDirectory>
    </None>
  </ItemGroup>
  <ItemGroup>
    <Using Include="System.Threading.ExecutionContext" Alias="ExecutionContext" />
  </ItemGroup>
</Project>

此外,在包含 Azure Functions 支持的 Visual Studio 安装程序中重试 Azure Developer 扩展工作负载安装。

作为替代方案,您也可以通过以下命令开始触发您的功能:-

func host start --verbose

请参阅此SO线程以获取更多见解。

© www.soinside.com 2019 - 2024. All rights reserved.