Skip to content
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

Improve libpython search #75

Open
devinrsmith opened this issue Jul 15, 2022 · 17 comments
Open

Improve libpython search #75

devinrsmith opened this issue Jul 15, 2022 · 17 comments
Assignees
Labels
bug Something isn't working

Comments

@devinrsmith
Copy link
Member

It seems that jpyutil is unable to properly find libpython3.8.so.1.0 on Ubuntu 20.04 (see deephaven/deephaven-core#2641).

https://packages.ubuntu.com/focal/amd64/libpython3.8/filelist:

/usr/lib/python3.8/config-3.8-x86_64-linux-gnu/libpython3.8.so
/usr/lib/x86_64-linux-gnu/libpython3.8.so.1
/usr/lib/x86_64-linux-gnu/libpython3.8.so.1.0

Maybe there is a more canonical way to reference the currently running libpython?

@devinrsmith devinrsmith added the bug Something isn't working label Jul 15, 2022
@devinrsmith devinrsmith self-assigned this Jul 15, 2022
@fabrice-ducos
Copy link

What about using python3-config?

@devinrsmith
Copy link
Member Author

python3-config looks like a solution for the build stage - for users at runtime though, where python may be installed elsewhere, I think ultimately the logic in jpyutil._find_python_dll_file needs to be improved to account for other canonical places (if python3-config happens to be installed, maybe it could be useful as a fallback?).

@fabrice-ducos
Copy link

Hi Devin,

if you look at python3-config's source code, it seems to be a simple Python script of 74 lines (with only dependencies to standard Python modules). Maybe the logic of that script could be adapted and embedded into jpyutil._find_python_dll_file.

Another solution: that jpy ships with its own copy of python3-config

Do I miss something there?

@devinrsmith
Copy link
Member Author

Nope - that sounds great. Do you have a link to the source repository? My quick googling didn't find it.

@devinrsmith
Copy link
Member Author

Or is this something that cpython maintains?

@fabrice-ducos
Copy link

I just "cat'ed" (or type'd if you are on a Windows platform) the copy of python3-config installed on my platform.

If you prefer to get the code from the "source", you will find it in the cpython repository:
python-config.in

You will notice that the extension is .in, not .py
It's actually Python code, but the shebang line (#!) seems to be replaced at deployment time by the actual path to the Python interpreter.

@devinrsmith
Copy link
Member Author

Here's a little gist, https://gist.github.com/devinrsmith/1d7ba0131c6bbe74ade1b7d293ae282e

I'm not able to replicate the issue @mofojed - we might need to look more closely at your setup?

@mofojed
Copy link

mofojed commented Oct 11, 2022

My python setup was out of date - I had a python command and python3 command, pointing to different installations:

➜  main git:(js-plugin-jetty) ✗ which python
/usr/bin/python
➜  main git:(js-plugin-jetty) ✗ python --version
Python 3.8.10
➜  main git:(js-plugin-jetty) ✗ which python3
/usr/local/bin/python3
➜  main git:(js-plugin-jetty) ✗ python3 --version
Python 3.8.2

Using the /usr/bin/python version 3.8.10 to create my venv resolved this issue. I cannot recall how these python versions got installed initially.

@devinrsmith
Copy link
Member Author

If this happens again,

JPY_LOG_LEVEL=DEBUG /path/to/venv/bin/python -c 'import jpyutil; print(jpyutil._find_python_dll_file())'

would be useful debug information.

@devinrsmith
Copy link
Member Author

https://cbs.centos.org/koji/rpminfo?rpmID=390332

I think virtual environments from "rh-python38 Software Collection" are incorrect; potentially, we need to include additional search paths, as in this case, it looks like the proper libpython is at

/opt/rh/rh-python38/root/usr/lib64/libpython3.8.so.rh-python38-1.0.

https://docs.python.org/3/library/sysconfig.html may be useful in these regards. In particular, potentially sysconfig.get_config_var("LDLIBRARY") / sysconfig.get_config_var("INSTSONAME"). Also, can see useful info using the module: python -m sysconfig.

Note: rh-python38 Software Collection is EOL, but just used as an example of how we may want to improve the search.

@devinrsmith
Copy link
Member Author

In the case of the rh-python38, we have INSTSONAME = "libpython3.8.so.rh-python38-1.0", which if used as an additional search name, would have found the correct libpython.

@devinrsmith
Copy link
Member Author

We may be able to better emulate (or even use the same apiis) as how library resolution happens when invoking the executable:

env LD_DEBUG=files,libs /path/to/venv/bin/python

produces useful data

@devinrsmith
Copy link
Member Author

@devinrsmith
Copy link
Member Author

python/cpython#119349
https://github.com/WardBrian/dllist

may be other options

devinrsmith added a commit to devinrsmith/jpy that referenced this issue Jan 6, 2025
This should be considered a partial improvement related to jpy-consortium#75.

A fuller solution might involve listing which shared objects were actually loaded via [`dl_iterate_phdr`](https://man7.org/linux/man-pages/man3/dl_iterate_phdr.3.html).

python/cpython#119349
@devinrsmith
Copy link
Member Author

devinrsmith commented Jan 6, 2025

https://man7.org/linux/man-pages/man3/dlinfo.3.html would be an api we could use as well to get l_name

Absolute pathname where object was found

since we know we only care about libpython; cribbing off of something like:

>>> from ctypes import *
>>> import sysconfig
>>> CDLL(sysconfig.get_config_var("INSTSONAME"))
<CDLL 'libpython3.9.so.1.0', handle 7fdf3bb9e000 at 0x7fdf3b3d5940>

@devinrsmith
Copy link
Member Author

>>> from ctypes import *
>>> from dlinfo import DLInfo
>>> import sysconfig
>>> libpython_handle = CDLL(sysconfig.get_config_var("INSTSONAME"))
>>> DLInfo(libpython_handle).path
'/lib64/libpython3.9.so.1.0'

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants