Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nanomsg/nng

nanomsg-next-generation -- light-weight brokerless messaging
https://github.com/nanomsg/nng

Last synced: 6 days ago
JSON representation

nanomsg-next-generation -- light-weight brokerless messaging

Awesome Lists containing this project

README

        

# nng - nanomsg-next-gen

[![Stand With Ukraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/badges/StandWithUkraine.svg)](https://stand-with-ukraine.pp.ua)
[![Linux Status](https://img.shields.io/github/actions/workflow/status/nanomsg/nng/linux.yml?branch=main&logoColor=grey&logo=linux&label=)](https://github.com/nanomsg/nng/actions)
[![Windows Status](https://img.shields.io/github/actions/workflow/status/nanomsg/nng/windows.yml?branch=main&logoColor=grey&logo=&label=)](https://github.com/nanomsg/nng/actions)
[![macOS Status](https://img.shields.io/github/actions/workflow/status/nanomsg/nng/darwin.yml?branch=main&logoColor=grey&logo=apple&label=)](https://github.com/nanomsg/nng/actions)
[![FreeBSD Status](https://img.shields.io/github/actions/workflow/status/nanomsg/nng/freebsd.yml?branch=main&logoColor=grey&logo=freebsd&label=)](https://github.com/nanomsg/nng/actions)
[![illumos Status](https://img.shields.io/github/actions/workflow/status/nanomsg/nng/omnios.yml?branch=main&logoColor=grey&logo=accuweather&label=)](https://github.com/nanomsg/nng/actions)
[![Coverage](https://img.shields.io/codecov/c/github/nanomsg/nng/branch/main?logo=codecov&logoColor=grey&label=)](https://codecov.io/gh/nanomsg/nng/tree/main)
[![Discord](https://img.shields.io/discord/639573728212156478?label=&logo=discord)](https://discord.gg/Xnac6b9)
[![Manual](https://img.shields.io/static/v1?label=&message=docs&logo=mdbook&logoColor=silver&color=blue)](https://nng.nanomsg.org/ref)
[![AsciiDoc](https://img.shields.io/static/v1?label=&message=docs&logo=asciidoctor&logoColor=silver&color=blue)](https://nng.nanomsg.org/man)
[![MIT License](https://img.shields.io/github/license/nanomsg/nng.svg?logoColor=silver&logo=open-source-initiative&label=&color=blue)](https://github.com/nanomsg/nng/blob/main/LICENSE.txt)
[![Latest Pre-Release](https://img.shields.io/github/v/release/nanomsg/nng.svg?logo=github&label=)](https://github.com/nanomsg/nng/releases)
[![Latest Release](https://img.shields.io/github/v/release/nanomsg/nng.svg?include_prereleases&logo=github&label=)](https://github.com/nanomsg/nng/releases)

Please see [here](UKRAINE.md) for an important message for the people of Russia.

> [!NOTE]
> This is the development branch for NNG.
> The content here is
> under development and may not be suitable for production use.
> Please use the [`stable`](https://github.com/nanomsg/nng/tree/stable) branch
> for the latest stable release.
>
> As a major release, there are some breaking API changes,
> but a [migration guide](docs/ref/migrate/nng1.md) is
> available to help with migrating from NNG 1.x.

> [!NOTE]
> If you are looking for the legacy version of nanomsg, please
> see the [libnanomsg](https://github.com/nanomsg/nanomsg) repository.

This project is a rewrite of the Scalability Protocols
library known as [nanomsg](https://github.com/nanomsg/nanomsg),
and adds significant new capabilities, while retaining
compatibility with the original.

It may help to think of this as "nanomsg-next-generation".

## NNG: Lightweight Messaging Library

NNG, like its predecessors [nanomsg](http://nanomsg.org) (and to some extent
[ZeroMQ](http://zeromq.org/)), is a lightweight, broker-less library,
offering a simple API to solve common recurring messaging problems,
such as publish/subscribe, RPC-style request/reply, or service discovery.
The API frees the programmer from worrying about details like connection
management, retries, and other common considerations, so that they
can focus on the application instead of the plumbing.

NNG is implemented in C, requiring only a relatively modern C compiler (C11) and CMake to build.
It can be built as a shared or a static library, and is readily
embeddable. It is also designed to be easy to port to new platforms
if your platform is not already supported.

## License

NNG is licensed under a liberal, and commercial friendly, MIT license.
The goal to the license is to minimize friction in adoption, use, and
contribution.

## Enhancements (Relative to nanomsg)

Here are areas where this project improves on "nanomsg":

- _Reliability_

NNG is designed for production use from the beginning.
Every error case is considered, and it is designed to avoid crashing except
in cases of gross developer error.
(Hopefully we don't have any of these in our own code.)

- _Scalability_

NNG scales out to engage multiple cores using a bespoke asynchronous I/O
framework, using thread pools to spread load without exceeding typical
system limits.

- _Maintainability_

NNG's architecture is designed to be modular and easily grasped by developers
unfamiliar with the code base. The code is also well documented.

- _Extensibility_

Because it avoids ties to file descriptors, and avoids confusing interlocking
state machines, it is easier to add new protocols and transports to NNG.
This was demonstrated by the addition of the TLS and ZeroTier transports.

- _Security_

NNG provides TLS (1.2 and optionally 1.3) and ZeroTier transports, offering
support for robust and industry standard authentication and encryption.
In addition, it is hardened to be resilient against malicious attackers,
with special consideration given to use in a hostile Internet.

- _Usability_

NNG eschews slavish adherence parts of the more complex and less well
understood POSIX APIs, while adopting the semantics that are familiar and
useful. New APIs are intuitive, and the optional support for separating
protocol context and state from sockets makes creating concurrent
applications vastly simpler than previously possible.

## Compatibility

This project offers both wire compatibility and API compatibility,
so most nanomsg users can begin using NNG right away.

Existing nanomsg and [mangos](https://github.com/nanomsg/mangos) applications
can inter-operate with NNG applications automatically.

That said, there are some areas where legacy nanomsg still offers
capabilities NNG lacks -- specifically enhanced observability with
statistics, and tunable prioritization of different destinations
are missing, but will be added in a future release.

Additionally, some API capabilities that are useful for foreign
language bindings are not implemented yet.

Some simple single threaded, synchronous applications may perform better under
legacy nanomsg than under NNG. (We believe that these applications are the
least commonly deployed, and least interesting from a performance perspective.
NNG's internal design is slightly less efficient in such scenarios, but it
greatly benefits when concurrency or when multiple sockets or network peers
are involved.)

## Supported Platforms

NNG supports Linux, macOS, Windows, illumos, Solaris,
FreeBSD, Android, and iOS.
It is regularly tested against macOS, Windows, OmniOS, Ubuntu, and FreeBSD.
Most other POSIX platforms should work out of
the box but have not been tested. Very old versions of otherwise supported
platforms might not work.

Officially, NNG only supports operating systems that are supported by
their vendors. For example, Windows versions 8.1 and lower are no longer
officially supported, and macOS versions predating Ventura are no longer
officially supported. Very old versions of systems may or may not work,
and we will generally expend no effort trying to make an unsupported system
function.
We generally only test relatively recent versions of supported systems.

## Requirements

To build this project, you will need a C11 compatible compiler and
[CMake](http://www.cmake.org) version 3.15 or newer.

We recommend using the [Ninja](https://ninja-build.org) build
system (pass `-G Ninja` to CMake) when you can.
(And not just because Ninja sounds like "NNG" -- it's also
blindingly fast and has made our lives as developers measurably better.)

If you want to build with TLS support you will also need
[Mbed TLS](https://tls.mbed.org) or [WolfSSL](https://wolfssl.com).
See the [build instructions](docs/BUILD_TLS.md) for details.

## Quick Start

With a Linux or UNIX environment:

```sh
$ mkdir build
$ cd build
$ cmake -G Ninja ..
$ ninja
$ ninja test
$ ninja install
```

## Reference Manual

The API documentation is currently in transition, as we are converting it from
Asciidoc to `mdbook`. Most of the content has now been converted, and you can
see it at [here](https://nng.nanomsg.org/ref). Part of the conversion includes
a substantial reorganization for improved usability, with major content revisions
and additions for NNG 2.0.

The remaining Asciidoc format documentation is in the `docs/man` subdirectory, and also
[online](https://nng.nanomsg.org/man). It will eventually all be converted before 2.0
is fully released.

You can also purchase a copy of the
[**NNG Reference Manual**](http://staysail.tech/books/nng_reference/index.html).
(It is published in both electronic and printed formats.)
Purchases of the book help fund continued development of NNG.

## Example Programs

Some demonstration programs have been created to help serve as examples.
These are located in the `demo` directory.

## Legacy Compatibility

Migration from `libnanomsg` APIs is fairly straight-forward for most applications.
A [migration guide](docs/ref/migrate/nanomsg.md) is available to assist.

## Commercial Support

Commercial support for NNG is available.

Please contact
[Staysail Systems, Inc.](mailto:[email protected])
to inquire further.

## Commercial Sponsors

The development of NNG has been made possible through the generous
sponsorship of
[Capitar IT Group BV](https://www.capitar.com)
and
[Staysail Systems, Inc.](http://staysail.tech).