Skip to main content

Avoid breakages that would occur from updating symlinks to running virtualenvs

Project description

Anchorer

Plugin for virtualenvwrapper that extends mkvirtualenv behaviour to add code that is loaded by the python interpreter for every run. The loaded code resolves symlinks in discovered site-package directories, allowing symlinks to virtualenvs to be updated while scripts/services are running.

Example problem anchorer solves

# assuming you have the virtualenvwrapper python package installed, and have sourced virtualenvwrapper.sh
mkvirtualenv env-v1
mkvirtualenv env-v2

# create a pseudo-virtualenv which is a symlink to a particular version
ln -s "$WORKON_HOME/env-v1" "$WORKON_HOME/active-env"

# now use the linked environment to start something in env-v1
workon active-env

# start some imaginary python service which may import modules a long time after starting
python -m my_long_runner &

# update the active symlink, switching what version
ln -sT "$WORKON_HOME/env-v2" "$WORKON_HOME/active-env"

# imagine at this point that my_long_runner tries to import a module, it will be using un-resolved paths which will mean
# the modules will be loaded from an environment that is not the one it started in

Architecture

  1. virtualenvwrapper.anchorer.fix.main() resolves paths that are used at runtime
    • current working directory
    • paths used for determining where packages are found
  2. virtualenvwrapper runs virtualenvwrapper.anchorer.plugin.pre_mkvirtualenv(...) during calls to mkvirtualenv to modify the virtualenv's site-packages directory:
    1. __anchorer.py is added, it is a copy of the fix module
    2. __anchorer.pth is added, it simply imports __anchorer which causes the main method to run. See site docs for more information on the mechanism

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

anchorer-0.4.0.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

anchorer-0.4.0-py3-none-any.whl (4.8 kB view details)

Uploaded Python 3

File details

Details for the file anchorer-0.4.0.tar.gz.

File metadata

  • Download URL: anchorer-0.4.0.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.15

File hashes

Hashes for anchorer-0.4.0.tar.gz
Algorithm Hash digest
SHA256 f2af82e8628fe8e796e2d1a42bb3ecb8bc8d4741aa0777169f0af25d52045d56
MD5 cb69699eac0d47c7edc325309fcd9c85
BLAKE2b-256 e75fb1bb22a524116bb151bf5f9bc7f5cc2afc4434394c4f6c73f180c65469c4

See more details on using hashes here.

File details

Details for the file anchorer-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: anchorer-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 4.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.15

File hashes

Hashes for anchorer-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c15970ec6c2a2b87a543e06bbe23ead924c4622f53f4bb256f8461582fd33e52
MD5 89ab512d1e803b1b37d63b21fa187eb5
BLAKE2b-256 f4a3832a005152ccbb06d1cda22c8561806a9da5985d8a463feea77132d2bd10

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page