NATS and Containers: Microservices at NATS Speed

Brian Flannery — December 11, 2015

NATS is all about simplicity and speed. In that regard, NATS is extremely well suited for microservices architectures, acting as a transport between services. Many NATS users I speak to in my role as community manager are using NATS for this purpose due to it’s lightweight PubSub characteristics. As services become increasingly distributed and modularized, an always-on, fast, PubSub communication layer becomes very important. NATS allows many distributed services and applications to function in real-time as a single entity. A large portion of these same NATS users are also using Docker for their containerized services.

NATS has integrated with Docker for some time—the original gnatsd Docker image was downloaded nearly a quarter-of-a-million times. Earlier this year, when Docker launched their Official Image program, and re-launched Docker Hub, the NATS team at Synadia updated the NATS Docker Image , and were approved for Docker Official Image Status.

In staying true to the NATS design philosophy, the NATS Docker image is very lightweight and simple. This was well illustrated in a tweet recently from David Williams:

If you’re not familiar with David, he gave an excellent talk on NATS at the meetup in August in San Francisco: Powered by NATS: Integration Patterns for Microservices Architectures.

Another recent update in the NATS container space is around Red Hat. Apcera, the corporate steward of NATS, was recently certified by Red Hat as a Technical Partner in their Container Zone, because NATS can run on RHEL. Here is an example of NATS running within a Docker container which starts FROM rhel.

NATS Docker on redhat

We’re excited to be partnering with leading open source companies like Red Hat and Docker to maintain the simplicity of using NATS in many different scenarios.

There’s some exciting updates to gnatsd which were recently made available on GitHub, and the team also recently added TLS support to a variety of clients inclduing(eg. Go, Ruby, Node.js, C). We’re constantly tuning NATS together with leaders in the open source community to provide a fast, simple, and secure way for you to scale your microservices architecture.

Give NATS a try, and let us know what you think in our Google Group or Slack Community, which you can find on our Community Page!


Back to Blog