0

我部署了基于 Java 的 Azure Functions 的新版本。现在,Azure 门户中我的 Azure Function 资源下的特定函数中出现以下错误:

Error: The function runtime is unable to start. Microsoft.Azure.WebJobs.ServiceBus: Could not load type 'Microsoft.Azure.ServiceBus.Management.ManagementClient' from assembly 'Microsoft.Azure.ServiceBus, Version=3.0.2.0, Culture=neutral, PublicKeyToken=7e34167dcc6d6d8c'. Session Id: a9f3c42dbb524ceca2c5158df9460c97 Timestamp: 2019-12-02T18:21:46.680Z

对我来说听起来有点像:https ://github.com/Azure/azure-functions-host/issues/3363

有趣的是,在上次部署之前,除了一些小的 Java 代码更改之外,我什么也没做。Function App 版本是否自动更新?

我还通过 kudu 和日志流(应用程序日志)检查了日志。

日志:

2019-12-02T11:08:04.412 [Information] Starting JobHost 2019-12-02T11:08:04.415 [Information] Starting Host (HostId=functionapp-dtw-worker-dp-master, InstanceId=aaab65a2-acef-4e4c-a8be-c3a1b13a795c, Version=2.0.12888.0, ProcessId=6860, AppDomainId=1, InDebugMode=True, InDiagnosticMode=False, FunctionsExtensionVersion=~2) 2019-12-02T11:08:04.467 [Information] Loading functions metadata 2019-12-02T11:08:04.495 [Information] 3 functions loaded 2019-12-02T11:08:04.812 [Information] Generating 3 job function(s) 2019-12-02T11:08:05.126 [Information] Found the following functions: Host.Functions.lastWillCronJobProcessor Host.Functions.serviceBusDeadLetterProcessor Host.Functions.serviceBusProcessor 2019-12-02T11:08:05.351 [Error] A host error has occurred during startup operation '7c3d76bc-730c-401a-86cb-27d04231d515'. System.TypeLoadException : Could not load type 'Microsoft.Azure.ServiceBus.Management.ManagementClient' from assembly 'Microsoft.Azure.ServiceBus, Version=3.0.2.0, Culture=neutral, PublicKeyToken=7e34167dcc6d6d8c'. at Microsoft.Azure.WebJobs.ServiceBus.Listeners.ServiceBusScaleMonitor..ctor(String functionId,EntityType entityType,String entityPath,String connectionString,Lazy1 receiver,ILoggerFactory loggerFactory)
at Microsoft.Azure.WebJobs.ServiceBus.Listeners.ServiceBusListener.<.ctor>b__18_0()
at System.Lazy1.ViaFactory(LazyThreadSafetyMode mode) at System.Lazy1.ExecutionAndPublication(LazyHelper executionAndPublication,Boolean useDefaultConstructor)
at System.Lazy1.CreateValue() at Microsoft.Azure.WebJobs.ServiceBus.Listeners.ServiceBusListener.GetMonitor() at Microsoft.Azure.WebJobs.Host.Listeners.HostListenerFactory.RegisterScaleMonitor(IListener listener,IScaleMonitorManager monitorManager) at C:\projects\azure-webjobs-sdk-rqm4t\src\Microsoft.Azure.WebJobs.Host\Listeners\HostListenerFactory.cs : 107 at async Microsoft.Azure.WebJobs.Host.Listeners.HostListenerFactory.CreateAsync(CancellationToken cancellationToken) at C:\projects\azure-webjobs-sdk-rqm4t\src\Microsoft.Azure.WebJobs.Host\Listeners\HostListenerFactory.cs : 69 at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Azure.WebJobs.Host.Listeners.ListenerFactoryListener.StartAsyncCore(CancellationToken cancellationToken) at C:\projects\azure-webjobs-sdk-rqm4t\src\Microsoft.Azure.WebJobs.Host\Listeners\ListenerFactoryListener.cs : 45 at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Azure.WebJobs.Host.Listeners.ShutdownListener.StartAsync(CancellationToken cancellationToken) at C:\projects\azure-webjobs-sdk-rqm4t\src\Microsoft.Azure.WebJobs.Host\Listeners\ShutdownListener.cs : 29 at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Azure.WebJobs.JobHost.StartAsyncCore(CancellationToken cancellationToken) at C:\projects\azure-webjobs-sdk-rqm4t\src\Microsoft.Azure.WebJobs.Host\JobHost.cs : 101 at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Azure.WebJobs.Script.ScriptHost.StartAsyncCore(CancellationToken cancellationToken) at C:\azure-webjobs-sdk-script\src\WebJobs.Script\Host\ScriptHost.cs : 249 at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Extensions.Hosting.Internal.Host.StartAsync(CancellationToken cancellationToken) at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at async Microsoft.Azure.WebJobs.Script.WebHost.WebJobsScriptHostService.UnsynchronizedStartHostAsync(ScriptHostStartupOperation activeOperation,Int32 attemptCount,JobHostStartupMode startupMode) at C:\azure-webjobs-sdk-script\src\WebJobs.Script.WebHost\WebJobsScriptHostService.cs : 235

日志流式传输:

与通过 kudu 的日志文件中相同的日志

你知道它为什么停止工作吗?老实说,我没有计划。服务总线的任何配置是否触发了更改?

在 Azure 门户中查看解决方案对于生产中的问题,请在打开错误之前在 Azure 门户中查看常见问题的解决方案。在 Azure 门户中,导航到您的函数应用 => 平台功能 => 诊断和解决问题以及相关仪表板,然后再打开您的问题。

调查信息 请提供以下信息:

时间戳:2019-12-02T18:21:46.680Z 函数应用程序版本(1.0 或 2.0):2.0.12888.0 (~2) 函数应用程序名称:functionapp-dtw-worker-dp-master 应用程序设置:FUNCTIONS_WORKER_RUNTIME:java 函数名称( s)(视情况而定):serviceBusProcessor 会话 ID:a9f3c42dbb524ceca2c5158df9460c97 地区:西欧 相关信息 提供任何相关信息

使用的编程语言:Java with Spring Boot、Spring Cloud Functions 使用的源绑定链接:ServiceBusTrigger、TimeTrigger

补充:我从这里将 .NET Core 版本等本地依赖项更新为最新的 v2.2.8:https ://dotnet.microsoft.com/download/dotnet-core/2.2

更新不会更改错误消息。当我使用 maven 插件“azure-functions-maven-plugin”版本 1.3.4 在本地启动该函数时,我得到了相同的错误异常,如下所示:

[12/2/2019 10:44:26 PM] Starting JobHost [12/2/2019 10:44:26 PM] Starting Host (HostId=n900b368-1683948780, InstanceId=889e113f-9129-4a24-8fbf-9b560addd68e, Version=2.0.12888.0, ProcessId=2368, AppDomainId=1, InDebugMode=False, InDiagnosticMode=False, FunctionsExtensionVersion=(null)) [12/2/2019 10:44:26 PM] Loading functions metadata [12/2/2019 10:44:26 PM] 3 functions loaded [12/2/2019 10:44:26 PM] Generating 3 job function(s) [12/2/2019 10:44:26 PM] Found the following functions: [12/2/2019 10:44:26 PM] Host.Functions.lastWillCronJobProcessor [12/2/2019 10:44:26 PM] Host.Functions.serviceBusDeadLetterProcessor [12/2/2019 10:44:26 PM] Host.Functions.serviceBusProcessor [12/2/2019 10:44:26 PM] [12/2/2019 10:44:26 PM] A host error has occurred during startup operation '03187631-f70a-45f5-9c3e-008568c4c6a4'. [12/2/2019 10:44:26 PM] Microsoft.Azure.WebJobs.ServiceBus: Could not load type 'Microsoft.Azure.ServiceBus.Management.ManagementClient' from assembly 'Microsoft.Azure.ServiceBus, Version=3.0.2.0, Culture=neutral, PublicKeyToken=7e34167dcc6d6d8c'. [12/2/2019 10:44:26 PM] Stopping JobHost

GitHub 问题报告:https ://github.com/Azure/azure-functions-host/issues/5317

您对解决这些问题有什么建议吗?

4

2 回答 2

0

似乎部署以某种方式删除了已安装的扩展。从 VSCode 部署后,我在 TS 函数中遇到了同样的错误。作为一种解决方法,我开始在同一个函数应用程序中创建一个新函数,使用的模板与我用于应用程序中的其他函数(例如 Azure 服务总线主题触发器)的模板相同。在我的情况下,这触发了所需扩展的新安装,并且错误消失了。

于 2019-12-03T13:02:12.807 回答
0

感谢您的提示和提示!我通过删除有问题的 bin 目录解决了这个问题。有关更多详细信息,请参阅:https ://github.com/Azure/azure-functions-host/issues/5317

解决方案摘自:https ://github.com/Azure/azure-functions-host/issues/5317

我已将应用程序设置“WEBSITE_RUN_FROM_PACKAGE”设置为 1,因此我部署了一个没有 bin 目录的新版本,现在它又可以工作了。非常感谢。

Azure Functions(Windows、代码、Java)的详细过程:

  1. mvn clean install 或 mvn clean package
  2. 从 /target/azure_function// 中删除 bin 目录
  3. mvn azure-functions:部署

PS:我正在为 Azure Functions 使用 maven 插件。

pom.xml:

<plugin>
        <groupId>com.microsoft.azure</groupId>
        <artifactId>azure-functions-maven-plugin</artifactId>
        <version>1.3.4</version>
<plugin>
于 2019-12-06T17:27:49.480 回答