ZeroMQ core engine in C++, implements ZMTP/3.1
Go to file
C-sir c2fae81460 Problem: my name is not in the AUTHORS file
Solution: add myself to the list
2024-05-10 15:45:28 +02:00
.github Add gssapi support to cmake 2024-05-08 10:06:39 +02:00
.obs obs: trigger build on merge 2023-06-18 15:40:05 +01:00
build_qnx Add support for QNX 7.1 build 2023-04-11 15:48:07 -04:00
builds Add gssapi support to cmake 2024-05-08 10:06:39 +02:00
doc Replace old website contribution page link with the page of the new website 2023-11-22 22:35:29 +00:00
external Problem: wepoll is out of date, known issues on Windows 2021-06-30 20:44:27 +01:00
include Problem: 4.3.5 is out, need new version 2023-10-09 12:21:03 +01:00
m4 Problem: posix_memalign autoconf check broken on some platforms 2019-01-19 21:06:23 +00:00
packaging Feature: modernize API documentation 2023-10-25 23:59:38 +02:00
perf Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
src Do not use _MSC_VER if windows 2024-04-23 21:00:20 +02:00
tests Fix typos in gssapi cmake support PR 2024-05-08 21:22:25 +02:00
tools Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
unittests Fix typos in gssapi cmake support PR 2024-05-08 21:22:25 +02:00
.clang-format Problem: clang-format produces C++11 style nested templated arguments 2019-07-12 18:04:30 +02:00
.clang-tidy add suppressions for clang-tidy-10 on ubuntu: 2021-03-03 14:26:17 -05:00
.git-blame-ignore-revs Problem: git blame became more difficult with clang-format change 2020-12-23 17:44:07 +00:00
.gitignore docs: add index page (#4615) 2023-11-01 09:49:25 +00:00
.hgeol Line-ending conversion rules for hg-git users and enabled use of .gitignore by hg-git users 2011-11-19 10:02:23 +01:00
.mailmap Fix mailmap entry for Max Skaller 2015-12-11 15:26:42 +01:00
.readthedocs.yaml Documentation: fix the HTMLZIP name to restore the download-documentation functionality (#4628) 2023-11-13 14:47:38 +00:00
.travis.yml Problem: Travis is no longer free for FLOSS projects 2021-09-22 16:42:09 +01:00
AUTHORS Problem: my name is not in the AUTHORS file 2024-05-10 15:45:28 +02:00
CMakeLists.txt Add gssapi support to cmake 2024-05-08 10:06:39 +02:00
Dockerfile make Docker image smaller + use `debian:buster-slim` base 2020-07-29 15:39:07 -04:00
Doxygen.cfg Problem: No default doxygen cfg for ZeroMQ project 2016-04-28 14:14:38 +01:00
INSTALL Fix typos 2022-02-11 00:45:06 +02:00
Jenkinsfile Replace `egrep` with `grep -E` 2023-08-26 22:19:35 +01:00
LICENSE Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
Makefile.am A clean-room implementation of zmq_proxy_steerable(). 2023-10-08 19:56:03 -04:00
NEWS Update NEWS for 4.3.5 2023-10-09 11:47:05 +01:00
README.cygwin.md Implement a definitive cygwin target for libzmq. 2014-12-29 17:39:19 -05:00
README.doxygen.md Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
README.md Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
SECURITY.md Problem: we lack an (internal) definition of severity for security issues 2020-05-09 13:03:02 +01:00
SupportedPlatforms.md Fix typos 2022-02-11 00:45:06 +02:00
acinclude.m4 Feature: modernize API documentation 2023-10-25 23:59:38 +02:00
appveyor.yml Problem: no permission to relicense tweetnacl integration 2023-06-04 23:54:31 +01:00
autogen.sh Relicense from LGPL3 + exceptions to Mozilla Public License version 2.0 2023-06-05 20:31:47 +01:00
branding.bmp Add ZeroMQ branding. 2012-06-12 21:30:24 -04:00
ci_build.sh Problem: coverage build script doesn't recognize several config options 2020-09-04 10:58:16 +02:00
ci_deploy.sh Problem: manual release OBS trigger is flaky 2022-04-08 01:23:51 +01:00
config.sh Changed more git:gihub.com to https://github.com 2022-09-22 02:47:22 +02:00
configure.ac Fix Autotools-generated `libzmq.pc` file 2024-03-21 12:22:43 +00:00
installer.ico Add ZeroMQ branding. 2012-06-12 21:30:24 -04:00
version.sh Replace `egrep` with `grep -E` 2023-08-26 22:19:35 +01:00

README.md

ZeroMQ

Build Status Build status Coverage Status Conan Center

Welcome

The ZeroMQ lightweight messaging kernel is a library which extends the standard socket interfaces with features traditionally provided by specialised messaging middleware products. ZeroMQ sockets provide an abstraction of asynchronous message queues, multiple messaging patterns, message filtering (subscriptions), seamless access to multiple transport protocols and more.

Supported platforms

Libzmq is mainly written in C++98 with some optional C++11-fragments. For configuration either autotools or CMake is employed. See below for some lists of platforms, where libzmq has been successfully compiled on.

Supported platforms with primary CI

OS and version Architecture Compiler and version Build system Remarks
Android NDK r25 arm, arm64, x86, x86_64 llvm (see NDK) autotools DRAFT
Ubuntu 14.04.5 LTS (trusty) amd64 clang 5.0.0 autotools STABLE, extras: GSSAPI, PGM, NORM, C++98 mode only
Ubuntu 14.04.5 LTS (trusty) amd64 gcc 4.8.4 autotools STABLE, DRAFT, extras: GSSAPI, PGM, NORM, TIPC, IPV6, also POLLER=poll, POLLER=select, also valgrind and address sanitizer executions
Ubuntu 14.04.5 LTS (trusty) amd64 gcc 4.8.4 CMake 3.12.2 STABLE
Windows Server 2012 R2 x86 Visual Studio 2008 CMake 3.12.2 DRAFT
Windows Server 2012 R2 x86 Visual Studio 2010 SP1 CMake 3.12.2 DRAFT
Windows Server 2012 R2 x86 Visual Studio 2012 Update 5 CMake 3.12.2 DRAFT
Windows Server 2012 R2 x86, amd64 Visual Studio 2013 Update 5 CMake 3.12.2 DRAFT, STABLE (x86 Release only), also POLLER=epoll
Windows Server 2012 R2 x86 Visual Studio 2015 Update 3 CMake 3.12.2 DRAFT
Windows Server 2016 x86 Visual Studio 2017 15.9.6 CMake 3.13.3 DRAFT
cygwin 3.0.0 on Windows Server 2012 R2 amd64 gcc 7.4.0 CMake 3.6.2 DRAFT
MSYS2 ? on Windows Server 2012 R2 amd64 gcc 6.4.0 CMake ? DRAFT
Mac OS X 10.13 amd64 Xcode 9.4.1, Apple LLVM 9.1.0 autotools STABLE, DRAFT
Mac OS X 10.13 amd64 Xcode 9.4.1, Apple LLVM 9.1.0 CMake 3.11.4 DRAFT

Note: the platforms are regularly updated by the service providers, so this information might get out of date without any changes on the side of libzmq. For Appveyor, refer to https://www.appveyor.com/updates/ regarding platform updates. For travis-ci, refer to https://changelog.travis-ci.com/ regarding platform updates.

Supported platforms with secondary CI

OS and version Architecture Compiler and version Build system Remarks
CentOS 6 x86, amd64 ? autotools
CentOS 7 amd64 ? autotools
Debian 8.0 x86, amd64 ? autotools
Debian 9.0 ARM64, x86, amd64 ? autotools
Fedora 28 ARM64, ARM32, amd64 ? autotools
Fedora 29 ARM64, ARM32, amd64 ? autotools
Fedora Rawhide ARM64, ARM32, amd64 ? autotools
RedHat Enterprise Linux 7 amd64, ppc64 ? autotools
SuSE Linux Enterprise 12 SP4 ARM64, amd64, ppc64, s390x ? autotools
SuSE Linux Enterprise 15 amd64 ? autotools
xUbuntu 12.04 x86, amd64 ? autotools
xUbuntu 14.04 x86, amd64 ? autotools
xUbuntu 16.04 x86, amd64 ? autotools
xUbuntu 18.04 x86, amd64 ? autotools
xUbuntu 18.10 x86, amd64 ? autotools

Supported platforms with known active users

At the time of writing, no explicit reports have been available. Please report your experiences by opening a PR adding an entry or moving an entry from the section below.

Under "last report", please name either the SHA1 in case of an unreleased version, or the version number in case of a released version.

OS and version Architecture Compiler and version Build system Last report Remarks
Solaris 10 x86, amd64, sparc GCC 8.1.0 CMake 2019/03/18
DragonFly BSD amd64 gcc 8.3 autotools 2018/08/07 git-72854e63
IBM i ppc64 gcc 6.3 autotools 2019/10/02 git-25320a3
QNX 7.0 x86_64 gcc 5.4.0 CMake 4.3.2
Windows 10 ARM64 Visual Studio 2019 CMake 2021/11/15 git-2375ca8b
Windows 10 ARM64 clang CMake 2021/11/15 git-2375ca8b

Supported platforms without known active users

Note: this list is incomplete and inaccurate and still needs some work.

OS and version Architecture Compiler and version Build system Remarks
Any Linux distribution x86, amd64 gcc ?+, clang ?+, icc ?+ autotools, CMake
SunOS, Solaris x86, amd64 SunPro autotools, CMake
GNU/kFreeBSD ? ? autotools, CMake
FreeBSD ? ? autotools, CMake
NetBSD ? ? autotools, CMake
OpenBSD ? ? autotools, CMake
DragonFly BSD amd64 gcc 8.3 autotools, CMake
HP-UX ? ? autotools, CMake
GNU/Hurd ? ? autotools
VxWorks 6.8 ? ? ?
Windows CE ? ? ?
Windows UWP ? ? ?
OpenVMS ? ? ?

Unsupported platforms

OS and version Architecture Compiler and version Remarks
QNX 6.3 ? gcc 3.3.5 see #3371, support was added by a user, but not contributed to upstream

For more details, see here.

For some platforms (Linux, Mac OS X), prebuilt binary packages are supplied by the ZeroMQ organization. For other platforms, you need to build your own binaries.

Installation of binary packages

Linux

For Linux users, pre-built binary packages are available for most distributions. Note that DRAFT APIs can change at any time without warning, pick a STABLE build to avoid having them enabled.

Latest releases

DEB

OBS release stable OBS release draft

RPM

OBS release stable OBS release draft

Bleeding edge packages

DEB

OBS release stable OBS release draft

RPM

OBS release stable OBS release draft

Example: Debian 9 latest release, no DRAFT apis

echo "deb http://download.opensuse.org/repositories/network:/messaging:/zeromq:/release-stable/Debian_9.0/ ./" >> /etc/apt/sources.list
wget https://download.opensuse.org/repositories/network:/messaging:/zeromq:/release-stable/Debian_9.0/Release.key -O- | sudo apt-key add
apt-get install libzmq3-dev

OSX

For OSX users, packages are available via brew.

brew install zeromq

Installation of package manager

vcpkg

vcpkg is a full platform package manager, you can easily install libzmq via vcpkg.

git clone https://github.com/microsoft/vcpkg.git
./bootstrap-vcpkg.bat # For powershell
./bootstrap-vcpkg.sh # For bash
./vcpkg install zeromq

Build from sources

To build from sources, see the INSTALL file included with the distribution.

Android

To build from source, see README file in the android build directory.

Resources

Extensive documentation is provided with the distribution. Refer to doc/zmq.html, or "man zmq" after you have installed libzmq on your system.

Website: http://www.zeromq.org/

Development mailing list: zeromq-dev@lists.zeromq.org Announcements mailing list: zeromq-announce@lists.zeromq.org

Git repository: http://github.com/zeromq/libzmq

ZeroMQ developers can also be found on the IRC channel #zeromq, on the Libera Chat network (irc.libera.chat).

License

The project license is specified in LICENSE.

libzmq is free software; you can redistribute it and/or modify it under the terms of the Mozilla Public License Version 2.0.

Contributing

This project uses C4(Collective Code Construction Contract) process for contributions.