繁体   English   中英

函数“FunctionName”的侦听器无法在 .net core azure 中启动

[英]The listener for function 'FunctionName' was unable to start in .net core azure

该应用程序使用模拟器在我的本地完美运行。 但是当我部署到 azure 进行测试时,我在日志中收到此错误。 我只有一个功能是时间触发器。

[10/12/2021 02:32:22 > 79e06d: INFO] 函数“DoWork”的监听器无法启动。 [10/12/2021 02:32:22 > 79e06d: INFO] Microsoft.Azure.WebJobs.Host.Listeners.FunctionListenerException:函数“DoWork”的侦听器无法启动。 [10/12/2021 02:32:22 > 79e06d: INFO] ---> System.Threading.Tasks.TaskCanceledException:任务被取消。 [10/12/2021 02:32:22 > 79e06d: INFO] 在 Microsoft.Azure.Storage.Core.Executor.Executor.ExecuteAsync[T](RESTCommand`1 cmd,IRetryPolicy 策略,OperationContext operationContext,CancellationToken 令牌)

我的应用设置中有这些

"AzureWebJobsStorage": "UseDevelopmentStorage=true", "FUNCTIONS_WORKER_RUNTIME": "dotnet",

如果您使用本地虚拟化存储模拟器,那么您的连接字符串是正确的。

{
    "AzureWebJobsStorage": "UseDevelopmentStorage=true", 
    "FUNCTIONS_WORKER_RUNTIME": "dotnet"
}

如果您的防火墙限制功能访问存储帐户,则可能会报告此错误。 防火墙是监听器无法访问虚拟存储模拟器的原因之一。

在本地运行该函数时,除http触发器之外的所有触发器都需要使用存储模拟器。 如果防火墙限制侦听器对虚拟存储的访问,则在执行功能时可能会出现问题。 这就是为什么使用 http 触发器不会出错的原因,因为它不使用虚拟存储模拟器。

尝试禁用防火墙,看看是否可以解决问题,在 cmd 中尝试以下语句以检查状态

"%programfiles(x86)%\Microsoft SDKs\Azure\Storage Emulator\AzureStorageEmulator.exe" status

如果返回 false,请输入以下命令以启动存储模拟器:

"%programfiles(x86)%\Microsoft SDKs\Azure\Storage Emulator\AzureStorageEmulator.exe" init
"%programfiles(x86)%\Microsoft SDKs\Azure\Storage Emulator\AzureStorageEmulator.exe" start

这种类型的问题通常是由三个原因造成的。

  1. 连接字符串错误阻止连接,
  2. 防火墙已设置
  3. 有些服务没有开启。 尝试将相同的代码复制到不同的位置。

安装并运行 Azure 存储模拟器 5.2 或更高版本。 使用真实的 Azure 存储连接字符串更新 local.appsettings.json 文件。

 {
    "AzureWebJobsStorage": "copy the string in the config function on azure",           
 }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM