-
-
Notifications
You must be signed in to change notification settings - Fork 416
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Azure function System.DllNotFoundException on linux #1567
Comments
How did you test it on Linux? Do you see the The |
Its not in the bin directory IIRC. Tried to use SkiaSharp as well, same issue there. Tested with an empty project, worked fine. As soon as it was an azure function it failed. To resolve it with SkiaSharp we added
I have been meaning to check if a similar workaround will work with magick, but have been a bit busy. |
I wonder if I could make this more convenient for you by also adding a |
Ok, so I got around to test it. The following worked for me locally, I have not tried it in azure, but I'm assuming it works since it did for SkiaSharp, so it should for this as well. What I did was add This should copy the .so file into the bin folder so that the code finds it.
|
I just created an function app to test if I can reproduce this. And I am unable to reproduce your issue. Would it be possible to share a trimmed down project that I can use to reproduce your issue? I did this in my test function: |
This repo should reproduce it, at least it does for me. |
Does it only fail in a unit test or also when running on Azure? |
It fails locally and in azure, I only named the function "Test", its not an actual unit test (my bad, bad naming). |
What OS are you testing on? I though Visual Studio wasn't available on Linux? I'm using JetBrains Rider. I tested the code above on an ubuntu VM, heres the full exception.
|
I am on Windows and publishing the application through Visual Studio on Azure. I suspect that Rider packages it differently. Not sure when I have time for this but I will setup VM and use rider there and check what they do. What you could do is go to your nuget cache and copy the .targets file from the netstandard20 folder to netstandard21 folder. (you need to create it) And then set the copy linux variable again. Does that work? |
Did my "patch" work for you @PetterKnudsen98? |
Magick.NET version
Magick.NET-Q16-x64
Environment (Operating system, version and so on)
Linux - Ubuntu 22.04.4
Description
Running .net 6 on an azure function v4 I get the following error message
System.DllNotFoundException: Unable to load shared library 'Magick.Native-Q16-x64.dll' or one of its dependencies. In order to help diagnose loading problems, consider setting the LD_DEBUG environment variable: libMagick.Native-Q16-x64.dll: cannot open shared object file: No such file or directory at ImageMagick.Environment.NativeMethods.X64.Environment_Initialize() at ImageMagick.Environment.NativeEnvironment.Initialize() in /_/src/Magick.NET/Native/Helpers/Environment.cs:line 65 at ImageMagick.Environment.Initialize() in /_/src/Magick.NET/Helpers/Environment.cs:line 21 at ImageMagick.MagickSettings.NativeMagickSettings..cctor() in /_/src/Magick.NET/Native/Settings/MagickSettings.cs:line 315
when executing the following code:
using var image = new MagickImage(imageStream);
My .csproj looks like this:
I have seen other suggest that
<MagickCopyNativeLinux>true</MagickCopyNativeLinux>
fixes the issue, but it doesnt seem to work for me. Is this an azure function issue, or am I just doing something wrong?It works fine on windows, and I'm not very experience with linux.
Steps to Reproduce
The text was updated successfully, but these errors were encountered: