-
Notifications
You must be signed in to change notification settings - Fork 792
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
An env var that disables path recompilation triggers. #4834
Comments
I'm definitely open to finding new ways to avoid recompilations, agreed this is a common source of pain. Is it definitely If it's related to |
A thing we previously considered was using base python for A thing we could try is:
This should reduce rebuilds significantly, I think? |
Yes, I've tried everything in the docs, setting PYO3_PYTHON, always source the same environment, but I have a workflow where I need to link against Pyo3 in a script to setup some daemons. And it always retriggers a full recompilation. The patch I mentioned above, works like a charm for me, but I would also make it work in open source Polars, where we don't want to patch pyo3. I believe it is triggered by PATH, but tbh, I gave up and just commented out all recompilation triggers 😅 . |
Have you got instructions to repro your workflow? I'd love to dig and try to understand if there's a general improvement without the nuclear option. @alex I think we record the virtual env executable so that downstream build scripts can potentially reference it. But I like your idea and I wonder if we can split the API so that at least our use case only depends on the base. |
@davidhewitt yes, that's exactly right, I'm trying to have our cake and eat it too :-) |
I can try if I can come up with a repro that is public, but what I do boils down to something like this. I have an I also call from fish into bash, which I believe modifies the path variable pyo3 sees. echo "PYO3_PYTHON = $PYO3_PYTHON"
PYTHON_LIBS=$(../.venv/bin/python -c "import site; print(site.getsitepackages()[0])")
echo "PYTHON_LIBS = $PYTHON_LIBS"
set -e
# compile two binaries (different dameons)
cargo build --bin mock_control_plane
cargo build --bin pc-cublet #--all-features
# We don't want to influence pyo3's builds, so mess with this after compilation!
PYTHON_SHARED_LIB=$(../.venv/bin/python -c "import sysconfig; print(sysconfig.get_config_var('LIBDIR'))")
export LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${PYTHON_SHARED_LIB}"
echo "LD_LIBRARY_PATH = $LD_LIBRARY_PATH"
# some other stuff
...
# start daemons Then I have another terminal where I repetitively call cargo check, and my LSP (rust analyzer) also calls into cargo. The combination In OSS Polars, I also often trigger a recompilation. In this case I haven't set PYO3_PYTHON and I believe it often happens when I switch branches or terminal tabs. |
I don't know if this makes sense, but one thing that always triggers a full recompile (even if PYO3_PYTHON) is set is alternating |
I would really love an environment var that disables all recompilation triggers of PyO3.
Currently I often patch pyo3 to prevent these recompilations.
I found it impossible to keep my path variable consistent in my flow, and given that pyo3 is used deep in our stack, this often triggers full 4/5min recompilations.
I know that the recompilations are done to prevent gnarly, bugs so I would document that env var (maybe not document at all) as "only use when you know what you are doing". Changes of paths, need to be followed up with a cargo clean.
The text was updated successfully, but these errors were encountered: