Skip to content

nanomsg/mangos

Folders and files

NameName
Last commit message
Last commit date
Feb 3, 2020
Oct 16, 2018
Aug 24, 2020
Aug 24, 2020
Feb 3, 2020
Mar 11, 2020
Sep 5, 2020
Aug 24, 2020
Feb 3, 2020
Jul 29, 2019
Dec 15, 2019
Dec 15, 2019
Nov 2, 2018
Oct 31, 2018
Feb 3, 2020
Nov 27, 2017
Oct 30, 2018
Feb 4, 2015
Feb 3, 2020
Oct 22, 2018
Sep 17, 2018
Feb 3, 2020
Feb 3, 2020
Feb 28, 2020
Feb 28, 2020
Sep 17, 2018
Mar 20, 2015
Dec 21, 2019
Oct 28, 2018
Oct 30, 2018
Nov 25, 2019
Oct 31, 2018
Dec 9, 2019

Repository files navigation

mangos

Linux Status Windows Status Darwin Status Coverage Code Quality Discord GoDoc Apache 2.0 License Latest version

Mangos™ is an implementation in pure Go of the SP (“Scalability Protocols”) messaging system. These are colloquially known as a “nanomsg”.

mangos
The import path has changed! Please change any references from nanomsg.org/go/mangos/v2 to go.nanomsg.org/mangos/v3. The old v2 imports will still work for old applications, provided that a sufficiently modern version of Go is used. However, no further work will be done on v2.
Tip
Versions 1 and 2 of mangos were at different import locations. Those versions will still inter-operate with this version, except that within the same process the inproc transport can only be used by consumers using the same version of mangos.

The modern C implementation of the SP protocols is available as NNG™.

The original implementation of the SP protocols is available as nanomsg™.

Generally (modulo a few caveats) all of these implementations can inter-operate.

The design is intended to make it easy to add new transports with almost trivial effort, as well as new topologies (“protocols” in SP parlance.)

At present, all of the Req/Rep, Pub/Sub, Pair, Bus, Push/Pull, and Surveyor/Respondent patterns are supported. This project also supports an experimental protocol called Star.

Supported transports include TCP, inproc, IPC, WebSocket, WebSocket/TLS and TLS.

Basic interoperability with nanomsg and NNG has been verified (you can do so yourself with nanocat and macat) for all protocols and transports that NNG and nanomsg support, except for the ZeroTier transport and the PAIRv1 protocol, which are only supported in NNG at this time.

There are a number of projects that use these products together.

Documentation

Testing

This package supports internal self tests, which can be run in the idiomatic Go way. (Note that most of the tests are in a test subdirectory.)

$ go test go.nanomsg.org/mangos/v3/...

There are also internal benchmarks available:

$ go test -bench=. go.nanomsg.org/mangos/v3/test

Commercial Support

Examples

Some examples are posted in the directories under examples/ in this project.

These examples are rewrites (in Go) of Tim Dysinger’s Getting Started with Nanomsg.

Running go doc in the example directories will yield information about how to run each example program.

Enjoy!


Copyright 2020 The Mangos Authors

mangos™, Nanomsg™ and NNG™ are trademarks of Garrett D’Amore.