-
Notifications
You must be signed in to change notification settings - Fork 73
Description
Affects: Both
Describe the bug
This is a bug that has plagued PyCall/PyJulia for a while and it seems the same issue occurs with PythonCall/juliacall. I've been discussing potential solutions with @mkitti for a while and am curious to hear what others think, in particular @cjdoris.
Basically, depending on your particular environment, you might see the following:
In [1]: import sklearn # Triggers load of incompatible libstdc++
In [2]: from juliacall import Main as jl
ERROR: Unable to load dependent library /home/mc2473/.julia/juliaup/julia-1.10.0+0.x64.linux.gnu/lib/julia/libjulia-codegen.so.1.10
Message:/lib64/libstdc++.so.6: version `GLIBCXX_3.4.26' not found (required by /home/mc2473/.julia/juliaup/julia-1.10.0+0.x64.linux.gnu/lib/julia/libjulia-codegen.so.1.10)
which crashes Python without providing any useful debug information. This issue is related to #255 which has been addressed in the documentation (as well as the PyJulia docs here).
In my opinion this is a really sharp corner of Python<->Julia interfaces, making them significantly less practical for end-users. I would really like to find a way to automatically solve this.
The simplest way to fix it is to preload the correct libstdc++ when starting Python, for example:
LD_PRELOAD=$HOME/.julia/juliaup/julia-1.10.0+0.x64.linux.gnu/lib/julia/libstdc++.so.6 ipython
Which is enough to solve the issue entirely. However this is not effective generally as you have to define it before python even starts.
The other solution is to import julia as early as possible. However, again, this is not a general solution as the julia import might occur deep in some dependency that an inexperienced end-user is simply not aware of.
So I'm wondering what options we have to actually fix this, once and for all (hopefully), so that an end-user won't have to run into this ever again. Maybe:
- Can we replace the loaded libstdc++ at runtime to the "correct" one as installed by julia?
- Can we load two versions of libstdc++ into Python at once? (Is that possible?)
- Can we install a static version of the relevant Julia libraries?
- Can we check, in advance, whether there will be a
GLIBCXX
issue, and prevent the Python hard crash – maybe using the opportunity to directly provide debugging information to the user?
What do you think?