-
Notifications
You must be signed in to change notification settings - Fork 639
Building and Installing PyZMQ
We build wheels for macOS and Windows, so we recommend that those platforms
use pip install pyzmq
.
We have pip wheels for all currently supported versions of Python, as well as some old, unsupported version of Python that still work, such as Python 2.7 which has reached end-of-life in January 2020 (for now).
We have binary installers for various Pythons on macOS and Windows, so you
should be able to just pip install pyzmq
in most situations. These
wheels include matching libzmq, so they should be the only thing you
need to start using pyzmq.
If a binary installer fails for you, please tell us about your system and the failure, so that we can try to fix it in later releases, and fall back on building from source.
pyzmq will try to build libzmq as a Python extension if it cannot find a libzmq to link against. This is thanks to work done in pyzmq_static.
To install pyzmq ignoring wheels, you can do:
pip install --no-binary pyzmq pyzmq
Linking against system libzmq is still the preferred mechanism, so pyzmq will try pretty hard to find it. You can skip the searching by explicitly specifying that pyzmq build its own libzmq:
$> pip install pyzmq --install-option="--zmq=bundled"
Or you can specify where your libzmq is to link against it explicitly:
$> pip install pyzmq --install-option="--zmq=/usr/local"
Cython is not required to build pyzmq from a release package, but it is required if you want to develop pyzmq, or build directly from our repository on GitHub.
On Windows, libzmq.dll will be copied into the zmq directory, and
installed along with pyzmq, so you shouldn't need to edit your PATH
.
It is best to compile both ØMQ and PyØMQ with Microsoft Visual Studio 2008 (2010 for Python ≥ 3.3). You should not need to use mingw. If you build libzmq with VS that does not match the one used to build Python, then there may be issues in error handling, because there will be a mismatch between error numbers.
To develop PyZMQ, you will need to install Cython, version 0.29 or greater. After installing Cython, do:
$ pip install -e .
This will build the C extension inplace and then put this directory on
your sys.path
. With this configuration you only have to run:
$ python setup.py build_ext --inplace
each time you change the .pyx
files. To clean the sources, you can do:
$ python setup.py clean
To run the test suite after building pyzmq in-place, install the test requirements:
$ pip install -r test-requirements
and run:
$ pytest
after an install or any changes you want to test