如何解决System.DllNotFoundException 无法在 Windows 容器中加载 DLL 'gdiplus.dll' 错误
我们正在使用 Kubernetes (Amazon EKS) 在 Windows 容器上运行 .Net 核心控制台应用程序。主机操作系统为 Windows Sever 2016。当 Aspose.Cells 生成 excel 文件时出现以下错误。
System.TypeInitializationException: The type initializer for 'Gdip' threw an exception. --->
System.DllNotFoundException: Unable to load DLL 'gdiplus.dll' or one of its dependencies:
The specified module could not be found.
正如 link 中所建议的那样,尝试使用 Windows 映像,以便 GDI 库在容器中可用,但没有奏效。下面是docker文件,
FROM mcr.microsoft.com/windows:1809
FROM mcr.microsoft.com/dotnet/runtime:5.0
SHELL ["powershell","-Command","$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
COPY ./ /App/WS
WORKDIR /App/WS
ENTRYPOINT ["dotnet","AppService.dll"]
也尝试过下面的图片,但没有运气。
FROM mcr.microsoft.com/dotnet/aspnet:5.0
FROM mcr.microsoft.com/dotnet/sdk:5.0
和
FROM mcr.microsoft.com/windows/servercore:ltsc2019
FROM mcr.microsoft.com/dotnet/runtime:5.0
linux 容器有一些选项可以显式安装 gdiPlus 库,但在 windows 容器中找不到类似的选项。目前,我们希望仅在 Windows 容器上部署我们的应用程序。感谢您的帮助!
解决方法
默认情况下,5.0
标记在定位 Windows 容器时为您提供 Windows Nano Server。 Windows 的此 SKU 已缩减,不包含 gdiplus.dll。您想要的是具有该 DLL 的 Windows Server Core。这在此处记录:https://github.com/dotnet/dotnet-docker/blob/main/documentation/scenarios/using-system-drawing-common.md。
根据我看到您引用的其他标签,您似乎将 Windows Server 2019 定位为用于您的容器。幸运的是,.NET 确实为 Windows Server Core 2019 提供了 .NET 5.0 映像。为此使用的标记是 5.0-windowsservercore-ltsc2019
。您可以在 https://hub.docker.com/_/microsoft-dotnet-runtime 中找到此列表。这将是用于解决此问题的推荐标记。
我怀疑您是否真的使用 Windows Server 2016 作为主机环境。没有任何版本的 Windows Server 能够使用比主机版本更新的 Windows 版本运行容器。此处描述了此 Windows 容器版本兼容性矩阵:https://docs.microsoft.com/en-us/virtualization/windowscontainers/deploy-containers/version-compatibility?tabs=windows-server-2016%2Cwindows-10-20H2。
我也对 Dockerfile 的内容感到有些困惑,因为您一直在列出两个连续的 FROM
指令。例如,您发布了以下内容:
FROM mcr.microsoft.com/windows:1809
FROM mcr.microsoft.com/dotnet/runtime:5.0
SHELL ["powershell","-Command","$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
COPY ./ /App/WS
WORKDIR /App/WS
ENTRYPOINT ["dotnet","AppService.dll"]
第一个 FROM
指令对生成的图像没有影响。在获取输出的图像中根本不使用 mcr.microsoft.com/windows:1809
基数,因为在它之后有后续的 FROM
指令。您似乎正在尝试将 mcr.microsoft.com/windows:1809
图像下拉以用作 mcr.microsoft.com/dotnet/runtime:5.0
图像的基础,但这不是它的工作原理。我鼓励你阅读 Dockerfile 结构。您可能还想了解如何将 .NET 安装到 .NET 未为其提供官方映像的其他映像类型上。这有点像你在这里尝试做的。但是在 https://github.com/dotnet/dotnet-docker/blob/main/documentation/scenarios/installing-dotnet.md 有关于如何做到这一点的官方指南。基本上,您可以像使用 mcr.microsoft.com/windows:1809
一样使用基础映像,并从其 zip 文件中明确安装 .NET。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。