# Awesome Microservices [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome) A curated list of Microservice Architecture related principles and technologies. **Table of Contents** - [Platforms](#platforms) - [Frameworks / Runtimes](#frameworks--runtimes) - [Service Toolkits](#service-toolkits) - [Polyglot](#polyglot) - [C](#c) - [C++](#c-1) - [C#](#csharp) - [D](#d) - [Erlang VM](#erlang-vm) - [Go](#go) - [Haskell](#haskell) - [Java VM](#java-vm) - [Node.js](#nodejs) - [Perl](#perl) - [PHP](#php) - [Python](#python) - [Ruby](#ruby) - [Capabilities](#capabilities) - [API Gateways / Edge Services](#api-gateways--edge-services) - [Coordination and Governance](#coordination-and-governance) - [Configuration and Discovery](#configuration-and-discovery) - [Security](#security) - [Job Schedulers / Workload Automation](#job-schedulers--workload-automation) - [Elasticity](#elasticity) - [Messaging](#messaging) - [Serialization](#serialization) - [Storage](#storage) - [Reactivity](#reactivity) - [Resilience](#resilience) - [Testing](#testing) - [Monitoring and Debugging](#monitoring-and-debugging) - [Logging](#logging) - [IT Automation / Provisioning](#it-automation--provisioning) - [Deployment and Continuous Integration](#deployment-and-continuous-integration) - [On-prem](#on-prem) - [Hosted](#hosted) - [Lightweight](#lightweight) - [Containers](#containers) - [Documentation & Modeling](#documentation--modeling) - [REST APIs](#rest-apis) - [Standards / Recommendations](#standards--recommendations) - [World Wide Web](#world-wide-web) - [HTTP/1.1](#http11) - [HTTP/2](#http2) - [CoAP](#coap) - [RPC](#rpc) - [Messaging](#messaging-1) - [Security](#security-1) - [Service Discovery](#service-discovery) - [Data Formats](#data-formats) - [Vocabularies](#vocabularies) - [Unicode](#unicode) - [Real Life Stories](#real-life-stories) - [Enterprise & Verticals](#enterprise--verticals) - [Theory](#theory) - [Articles & Papers](#articles--papers) - [Talks](#talks) - [Tutorials](#tutorials) - [Books](#books) - [Sites](#sites) - [Emerging Technologies](#emerging-technologies) - [License](#license) - [Contributing](#contributing) - [Acknowledgments](#acknowledgments) ## Platforms - [Cisco Microservices](https://github.com/CiscoCloud/microservices-infrastructure) - Modern platform for rapidly deploying globally distributed services. - [Cocaine](https://github.com/cocaine) - A cloud platform enabling you to build your own PaaS clouds. - [Deis](http://deis.io/) - Open source application platform for public and private clouds. - [Fabric8](http://fabric8.io/) - Open source microservices platform based on Docker, Kubernetes and Jenkins. Makes it easy to create, edit, deploy and manage microservices and go faster. - [Hook.io](https://hook.io/) - Open source hosting platform for microservices. - [Lattice](http://lattice.cf/) - Open source project for running containerized workloads on a cluster. Lattice bundles up http load-balancing, a cluster scheduler, log aggregation/streaming and health management into an easy-to-deploy and easy-to-use package. - [Lightbend](https://www.lightbend.com/) - Platform for building scalable reactive systems on the JVM. - [Netflix OSS](https://netflix.github.io/) - Netflix open source software ecosystem. - [Spring Cloud Netflix](https://github.com/spring-cloud/spring-cloud-netflix) - Provides Netflix OSS integrations for Spring Boot apps through autoconfiguration and binding to the Spring Environment and other Spring programming model idioms. - [VAMP](http://vamp.io/) - Build, deploy and manage microservices with power and ease. ## Frameworks / Runtimes - [Akka](http://akka.io/) - Toolkit and runtime for building highly concurrent, distributed, and resilient message-driven applications on the JVM. - [Baratine](http://baratine.io/) - Platform for building a network of loosely-coupled POJO microservices. - [Erlang/OTP](https://github.com/erlang/otp) - Programming language used to build massively scalable soft real-time systems with requirements on high availability. - [Finagle](http://twitter.github.io/finagle) - Extensible RPC system for the JVM, used to construct high-concurrency servers. - [GPars](https://github.com/GPars/GPars) - Concurrency and parallelism framework for the JVM. - [Ice](https://zeroc.com/) - Comprehensive RPC framework with support for C++, C#, Java, JavaScript, Python, and more. - [Karyon](https://github.com/Netflix/karyon) - The nucleus or the base container for applications and services built using the NetflixOSS ecosystem. - [Lagom](https://github.com/lagom/lagom) - Reactive microservices for the JVM. - [Light Java](https://github.com/networknt/light-java) - A fast, lightweight and more productive microservices framework. - [Microserver](https://github.com/aol/micro-server) - Java 8 native, zero configuration, standards based, battle hardened library to run Java REST microservices. - [Orbit](http://orbit.bioware.com/) - Modern framework for JVM languages that makes it easier to build and maintain distributed and scalable online services. - [Quasar](https://github.com/puniverse/quasar) - Fibers, channels and actors for the JVM. - [Scale Cube](http://scalecube.io/) - Library for building resilient and reactive microservices with peer-to-peer service registry and discovery based on gossip protocol. - [Squeezer](https://squeezer.io) - Event-driven APIs and web applications running as microservices, serverless. - [Vert.X](http://vertx.io/) - Toolkit for building reactive applications on the JVM. - [Vert.X Toolbox](https://github.com/vert-x3/vertx-microservices-toolbox) - A set of Vert.x components to build reactive microservice applications. - [Wangle](https://github.com/facebook/wangle) - A framework providing a set of common client/server abstractions for building services in a consistent, modular, and composable way. ## Service Toolkits ### Polyglot - [Apex](https://github.com/apex/apex) - Tool for deploying and managing AWS Lambda functions. With shims for languages not yet supported by Lambda, you can use Golang out of the box. - [CoAP](http://coap.technology/impls.html) - Constrained application protocol implementations. - [GRPC](http://www.grpc.io/) - A high performance, open source, general RPC framework that puts mobile and HTTP/2 first. Libraries in C, C++, Java, Go, Node.js, Python, Ruby, Objective-C, PHP and C#. - [Hprose](http://github.com/hprose) - A very newbility RPC Library, support 25+ languages now. ### C - [Kore](https://kore.io/) - Easy to use web application framework for writing scalable web APIs in C. - [Libasyncd](https://github.com/wolkykim/libasyncd/) - Embeddable event-based asynchronous HTTP server library for C. - [Libslack](http://libslack.org/) - Provides a generic agent oriented programming model, run time selection of locking strategies, functions that make writing daemons trivial and simplify the implementation of network servers and clients, &c. - [Lwan](http://lwan.ws/) - High-performance and scalable web server. - [Onion](https://github.com/davidmoreno/onion) - C library to create simple HTTP servers and web applications. - [RIBS2](https://github.com/Adaptv/ribs2) - Library which allows building high-performance internet serving systems. ### C++ - [AnyRPC](https://github.com/sgieseking/anyrpc) - Provides a common system to work with a number of different remote procedure call standards, including: JSON-RPC, XML-RPC, MessagePack-RPC. - [Cap’n Proto RPC](https://capnproto.org/cxxrpc.html) - The Cap’n Proto C++ RPC implementation. - [C++ Micro Services](http://cppmicroservices.org/) - An OSGi-like C++ dynamic module system and service registry. - [Enduro/X](https://github.com/endurox-dev/endurox/) - XATMI based service framework for GNU/Linux. - [Pion](https://github.com/splunk/pion) - C++ framework for building lightweight HTTP interfaces. - [Pistache](https://github.com/oktal/pistache) - A high-performance REST toolkit written in C++. - [Poco](http://pocoproject.org/) - C++ class libraries for building network-based applications and servers. - [Restbed](https://github.com/Corvusoft/restbed) - Brings asynchronous RESTful functionality to C++11 applications. - [Served](https://github.com/datasift/served) - C++ library for building high-performance RESTful web servers. - [ULib](https://github.com/stefanocasazza/ULib) - Highly optimized class framework for writing C++ applications. ### CSharp - [Akka.NET](http://getakka.net/) - Toolkit and runtime for building highly concurrent, distributed, and fault tolerant event-driven applications on .NET & Mono. - [Nancy](http://nancyfx.org/) - Lightweight web framework. ### D - [Vibe.d](http://vibed.org/) - Asynchronous I/O that doesn’t get in your way, written in D. ### Erlang VM #### Elixir - [Phoenix](http://www.phoenixframework.org/) - Framework for building HTML5 apps, API backends and distributed systems. - [Plug](https://github.com/elixir-lang/plug) - A specification and conveniences for composable modules between web applications. #### Erlang - [Cowboy](https://github.com/ninenines/cowboy) - Small, fast, modular HTTP server written in Erlang. - [Gen Microservice](https://github.com/videlalvaro/gen_microservice) - This library solves the problem of implementing microservices with Erlang. - [Mochiweb](https://github.com/mochi/mochiweb) - Erlang library for building lightweight HTTP servers. ### Go - [Echo](https://echo.labstack.com/) - Fast and unfancy HTTP server framework for Go. Up to 10x faster than the rest. - [Gizmo](https://github.com/nytimes/gizmo) - Microservices toolkit. - [Goa](https://github.com/goadesign/goa) - Design-based HTTP microservices in Go. - [Gocraft](https://github.com/gocraft/web) - A toolkit for building web apps. Includes routing, middleware stacks, logging and monitoring. - [Goji](https://goji.io/) - Minimalistic and flexible request multiplexer for Go. - [Go kit](https://github.com/go-kit/kit) - Distributed programming toolkit for microservices in the modern enterprise. - [Go-micro](https://github.com/micro/go-micro) - A pluggable RPC microservice framework. - [Gopencils](https://github.com/bndr/gopencils) - Easily consume REST APIs with Go. - [Gorilla](http://www.gorillatoolkit.org/) - Web toolkit for the Go programming language. - [Kite](https://github.com/koding/kite) - Microservices framework in Go. - [Libchan](https://github.com/docker/libchan) - Ultra-lightweight networking library which lets network services communicate in the same way that goroutines communicate using channels. - [Micro](https://github.com/micro/micro) - A microservices toolchain in Go. - [Nano](https://github.com/pasztorpisti/nano) - A minimalistic, transport-agnostic and testing-friendly microservice framework. - [Negroni](https://github.com/codegangsta/negroni) - Idiomatic HTTP middleware for Golang. - [Neutrino](https://github.com/neutrinoapp/neutrino) - Realtime/REST backend service. - [RPCX](https://github.com/smallnest/rpcx) - A distributed RPC service framework based on NET/RPC like Alibaba Dubbo and Weibo Motan. - [Sleepy](https://github.com/dougblack/sleepy) - REST for go. - [Vamp-router](https://github.com/magneticio/vamp-router) - Service routing, load balancing and filtering application. - [Zerver](https://github.com/cosiner/zerver) - RESTful API framework. ### Haskell - [Scotty](https://github.com/scotty-web/scotty) - Micro web framework inspired by Ruby's Sinatra, using WAI and Warp. - [Servant](https://github.com/haskell-servant/servant) - Type-level web DSL. - [Yesod](https://github.com/yesodweb/yesod) - The Haskell RESTful web framework. ### Java VM #### Clojure - [Compojure](https://github.com/weavejester/compojure) - A concise routing library for Ring/Clojure. - [Duct](https://github.com/weavejester/duct) - Minimal framework for building web applications in Clojure, with a strong emphasis on simplicity. - [Friboo](https://github.com/zalando/friboo) - Utility library for writing microservices in Clojure, with support for Swagger and OAuth. - [Liberator](http://clojure-liberator.github.io/liberator/) - Library that helps you expose your data as resources while automatically complying with all the relevant requirements of the HTTP specification. - [Modularity](https://modularity.org/) - JUXT's Clojure-based modular system. - [System](https://github.com/danielsz/system) - Built on top of Stuart Sierra's component library, offers a set of readymade components. - [Tesla](https://github.com/otto-de/tesla-microservice) - Common basis for some of Otto.de's Clojure microservices. #### Java - [Airlift](https://github.com/airlift/airlift) - Framework for building REST services in Java. - [Disruptor](https://github.com/LMAX-Exchange/disruptor) - High-performance inter-thread messaging library. - [Dropwizard](https://dropwizard.github.io/) - Java framework for developing ops-friendly, high-performance, RESTful web services. - [HTTP Remoting](https://github.com/palantir/http-remoting) - Libraries for defining and creating RESTish/RPC servers and clients based on Feign or Retrofit as a client and Dropwizard/Jersey with JAX-RS service definitions as a server. - [Jersey](https://jersey.github.io/) - RESTful services in Java. JAX-RS reference implementation. - [MSF4J](https://github.com/wso2/msf4j) - High throughput & low memory footprint Java microservices framework. - [QBit](https://github.com/advantageous/qbit) - Reactive programming library for building microservices. - [Ratpack](https://ratpack.io/) - Set of Java libraries that facilitate fast, efficient, evolvable and well tested HTTP applications. specific support for the Groovy language is provided. - [Restlet](http://restlet.com/) - Helps Java developers build web APIs that follow the REST architecture style. - [Spark](http://sparkjava.com/) - A micro-framework for creating web applications in Java 8 with minimal effort. - [Spring Boot](http://projects.spring.io/spring-boot/) - Makes it easy to create stand-alone, production-grade Spring based applications. #### Scala - [Akka HTTP](http://doc.akka.io/docs/akka-http/current/scala.html) - Open source toolkit for building REST/HTTP-based integration layers on top of Scala and Akka (will replace Spray). - [Colossus](https://github.com/tumblr/colossus) - I/O and microservice library for Scala. - [Finatra](http://twitter.github.io/finatra/) - Fast, testable, Scala HTTP services built on Twitter-Server and Finagle. - [Http4s](http://http4s.org/) - A minimal, idiomatic Scala interface for HTTP - [Play](https://www.playframework.com/) - The high velocity web framework for Java and Scala. - [Scalatra](http://www.scalatra.org/) - Simple, accessible and free web micro-framework. - [Skinny Micro](https://github.com/skinny-framework/skinny-micro) - Micro-web framework to build servlet applications in Scala. - [Spray](http://spray.io/) - Open source toolkit for building REST/HTTP-based integration layers on top of Scala and Akka. - [Squbs](http://paypal.github.io/squbs/) - A suite of components enabling standardization and operationalization of Akka and Spray applications/services in a large scale, managed, cloud environment. ### Node.js - [Actionhero](http://www.actionherojs.com/) - Multi-transport Node.js API server with integrated cluster capabilities and delayed tasks. - [Baucis](https://github.com/wprl/baucis) - To build and maintain scalable HATEOAS/Level 3 REST APIs. - [Express](http://expressjs.com/) - Fast, unopinionated, minimalist web framework for Node.js - [FeathersJS](http://feathersjs.com/) - An open source REST and realtime API layer for modern applications. - [Graft](https://github.com/GraftJS/graft) - Full-stack javascript through microservices. - [Hapi](http://hapijs.com/) - A rich framework for building applications and services. - [Hudson Taylor](https://github.com/hudson-taylor/hudson-taylor) - Set of libraries for building automatically documented, well validated services. - [Koa](http://koajs.com/) - Next generation web framework for Node.js - [Loopback](http://loopback.io/) - Node.js framework for creating APIs and easily connecting to backend data sources. - [Micro](http://github.com/zeithq/micro) - Asynchronous HTTP microservices. - [Micro-Whalla](https://github.com/czerwonkabartosz/Micro-Whalla) - A simple, fast framework for writing microservices in Node.js communicate using RPC / IPC. - [Moleculer](http://moleculer.services/) - Fast & powerful microservices framework for NodeJS. - [Restify](http://restify.com/) - Node.js module built specifically to enable you to build correct REST web services. - [Seneca](http://senecajs.org/) - A microservices toolkit for Node.js - [Serverless](https://github.com/serverless/serverless) - Build and maintain web, mobile and IoT applications running on AWS Lambda and API Gateway (formerly known as JAWS). - [StdLib](https://stdlib.com/) - Standard library for microservices. ### Perl - [Mojolicious](http://mojolicio.us/) - Next generation web framework for Perl. ### PHP - [API Platform](https://api-platform.com/) - API-first web framework on top of Symfony with JSON-LD, Schema.org and Hydra support. - [Lumen](https://lumen.laravel.com/) - Stunningly fast micro-framework. - [Phalcon](https://phalconphp.com/) - Full-stack PHP framework delivered as a C-extension. - [Silex](http://silex.sensiolabs.org/) - Micro-framework based on the Symfony components. - [Slim](http://www.slimframework.com/) - Micro-framework that helps you quickly write simple yet powerful web applications and APIs. ### Python - [API Star](https://github.com/tomchristie/apistar) - A fast and expressive API framework, designed for Python 3. - [Flask](http://flask.pocoo.org/) - Python framework for microservices based on Werkzeug and Jinja 2. - [Nameko](https://github.com/onefinestay/nameko) - Python framework for building microservices. - [Sanic](https://github.com/channelcat/sanic) - Sanic is a Flask-like Python 3.5+ web server that's written to go fast. - [Tornado](http://www.tornadoweb.org/) - Web framework and asynchronous networking library. - [Twisted](https://twistedmatrix.com/trac/) - Event-driven network programming engine. - [Web.py](https://github.com/webpy/webpy/) - Minimalist web framework for Python. - [Zappa](https://github.com/Miserlou/Zappa) - Framework for building and deploying server-less Python event-driven and web applications. ### Ruby - [Hanami](https://github.com/hanami) - A modern web framework for Ruby. - [Praxis](https://github.com/rightscale/praxis) - Framework for both designing and implementing APIs. - [Scorched](https://github.com/wardrop/Scorched) - Light-weight web framework for Ruby. ## Capabilities ### API Gateways / Edge Services - [Amalgam8](https://github.com/amalgam8) - Content-based routing fabric for polyglot microservices. - [Annon](https://github.com/nebo15/annon.api) - Open source API gateway with built-in API management, authentication and status pages written in Elixir. - [Caddy](https://caddyserver.com/) - Extensible HTTP/2 web server with automatic HTTPS. - [Camel](http://camel.apache.org/) - Empowers you to define routing and mediation rules in a variety of domain-specific languages, including a Java-based fluent API, Spring or Blueprint XML configuration files, and a Scala DSL. - [Envoy](https://github.com/lyft/envoy) - Open source edge and service proxy, from the developers at Lyft. - [Fabio](https://github.com/eBay/fabio) - A fast, modern, zero-conf load balancing HTTP/S router for deploying microservices managed by Consul. - [HAProxy](http://www.haproxy.org/) - Reliable, high Performance TCP/HTTP load balancer. - [Keepalived](http://www.keepalived.org/) - Simple and robust facilities for loadbalancing and high-availability to Linux system and Linux based infrastructures. - [Kong](https://getkong.org/) - Open source management layer for APIs. - [Linkerd](https://linkerd.io/) - Resilient service mesh for cloud native apps. - [Neutrino](https://github.com/eBay/Neutrino) - Extensible software load balancer. - [OpenResty](http://openresty.org/) - Fast web application server built on top of Nginx. - [Skipper](https://github.com/zalando/skipper) - HTTP router useful for decoupling routing from service logic. - [Tengine](http://tengine.taobao.org/) - A distribution of Nginx with some advanced features. - [Træfɪk](http://traefik.io/) - A modern HTTP reverse proxy and load balancer made to deploy microservices with ease. - [Tyk](https://tyk.io/) - Open source, fast and scalable API gateway, portal and API management platform. - [Vulcand](https://github.com/vulcand/vulcand) - Programmatic load balancer backed by Etcd. - [Zuul](https://github.com/Netflix/zuul) - An edge service that provides dynamic routing, monitoring, resiliency, security, and more. ### Coordination and Governance - [AWS Step Functions](https://aws.amazon.com/step-functions/) :small_orange_diamond: commercial - Coordinate the components of distributed applications and microservices using visual workflows. - [Azuqua](https://azuqua.com/) :small_orange_diamond: commercial - Orchestration and governance platform for distributed applications. - [Conductor](https://github.com/Netflix/conductor) - A microservices orchestration engine. ### Configuration and Discovery - [Consul](https://www.consul.io/) - Service discovery and configuration made easy. Distributed, highly available, and datacenter-aware. - [ContainerPilot](https://github.com/joyent/containerpilot) - Service for autodiscovery and configuration of applications running in containers. - [Denominator](https://github.com/Netflix/denominator) - Portably control DNS clouds using java or bash. - [Doozer](https://github.com/ha/doozerd) - Highly-available, completely consistent store for small amounts of data. When the data changes, it can notify connected clients immediately. - [Etcd](https://github.com/coreos/etcd) - Highly-available key-value store for shared configuration and service discovery. - [Eureka](https://github.com/Netflix/eureka/wiki/Eureka-at-a-glance) - REST based service that is primarily used in the AWS cloud for locating services for the purpose of load balancing and failover of middle-tier servers. - [Microphone](https://github.com/rogeralsing/Microphone) - Lightweight .NET framework to run self hosting REST services using Web Api or NancyFx on top of a Consul or Etcd cluster. - [Registrator](https://github.com/gliderlabs/registrator) - Service registry bridge for Docker. Supports pluggable service registries, which currently includes Consul, Etcd and SkyDNS 2. - [Shaman](https://github.com/nanopack/shaman) - Small, lightweight, api-driven DNS server. - [SkyDNS](https://github.com/skynetservices/skydns) - Distributed service for announcement and discovery of services built on top of etcd. It utilizes DNS queries to discover available services. - [SmartStack](https://github.com/airbnb/smartstack-cookbook) - Airbnb's automated service discovery and registration framework. - [Spring Cloud Config](http://cloud.spring.io/spring-cloud-config/) - Provides server and client-side support for externalized configuration in a distributed system. - [ZooKeeper](https://zookeeper.apache.org/) - Open source server which enables highly reliable distributed coordination. ### Security - [Crtauth](https://github.com/spotify/crtauth) - A public key backed client/server authentication system. - [Dex](https://github.com/coreos/dex) - Opinionated auth/directory service with pluggable connectors. OpenID Connect provider and third-party OAuth 2.0 delegation. - [JWT](http://jwt.io/) - JSON Web Tokens are an open, industry standard RFC 7519 method for representing claims securely between two parties. - [Keycloak](https://github.com/keycloak/keycloak) - Full-featured and extensible auth service. OpenID Connect provider and third-party OAuth 2.0 delegation. - [Light OAuth2](https://github.com/networknt/light-oauth2) - A fast, lightweight and cloud native OAuth 2.0 authorization microservices based on light-java. - [login-with](https://github.com/lipp/login-with) - Stateless login-with microservice for Google, FB, Github, etc. - [OAuth](http://oauth.net/2/) - Provides specific authorization flows for web applications, desktop applications, mobile phones, and living room devices. Many implementations. - [OpenID Connect](http://openid.net/developers/libraries/) - Libraries, products, and tools implementing current OpenID specifications and related specs. - [OSIAM](https://github.com/osiam/osiam) - Open source identity and access management implementing OAuth 2.0 and SCIMv2. - [SCIM](http://www.simplecloud.info/) - System for Cross-domain Identity Management. - [Vault](https://www.vaultproject.io/) - Secures, stores, and tightly controls access to tokens, passwords, certificates, API keys, and other secrets in modern computing. ### Job Schedulers / Workload Automation - [Celery](http://www.celeryproject.org) - Asynchronous task queue/job queue based on distributed message passing. Focused on real-time operation and supports scheduling. - [Chronos](https://github.com/mesos/chronos) - Fault tolerant job scheduler for Mesos which handles dependencies and ISO8601 based schedules. - [Fenzo](https://github.com/Netflix/Fenzo) - Extensible scheduler for Mesos frameworks. - [JobScheduler](http://www.sos-berlin.com/jobscheduler) - Open Source solution for enterprise-level workload automation. It is used to launch executable files and shell scripts and to run database procedures automatically. - [OpenLava](http://www.openlava.org/) - Workload scheduler that supports a variety of HPC and analytic applications. - [Rundeck](http://rundeck.org/) - Job scheduler and runbook automation. Enable self-service access to existing scripts and tools. - [Schedulix](http://www.schedulix.org/en) - Open source enterprise job scheduling system lays down ground-breaking standards for the professional automation of IT processes in advanced system environments. ### Elasticity - [Galaxy](http://www.paralleluniverse.co/galaxy/) - Open source high-performance in-memory data-grid. - [Grape](http://reverbrain.com/grape/) - Realtime processing pipeline. - [Hazelcast](http://hazelcast.org/) - Open source in-memory data-grid. Allows you to distribute data and computation across servers, clusters and geographies, and to manage very large data sets or high data ingest rates. Mature technology. - [Helix](http://helix.apache.org/) - Generic cluster management framework used for the automatic management of partitioned, replicated and distributed resources hosted on a cluster of nodes. - [Ignite](http://ignite.apache.org/) - High-performance, integrated and distributed in-memory platform for computing and transacting on large-scale data sets in real-time, orders of magnitude faster than possible with traditional disk-based or flash technologies. - [Marathon](https://mesosphere.github.io/marathon/) - Deploy and manage containers (including Docker) on top of Apache Mesos at scale. - [Mesos](https://mesos.apache.org/) - Abstracts CPU, memory, storage, and other compute resources away from machines (physical or virtual), enabling fault-tolerant and elastic distributed systems to easily be built and run effectively. - [Nomad](https://www.nomadproject.io/) - Distributed, highly available, datacenter-aware scheduler. - [Onyx](https://github.com/onyx-platform/onyx) - Distributed, masterless, high performance, fault tolerant data processing for Clojure. - [Ordasity](https://github.com/boundary/ordasity) - Designed to spread persistent or long-lived workloads across several machines. - [Redisson](https://github.com/mrniko/redisson) - Distributed and scalable Java data structures on top of Redis server. - [Serf](https://www.serfdom.io/) - Decentralized solution for cluster membership, failure detection and orchestration. ### Messaging - [ØMQ](http://zeromq.org/) - Brokerless intelligent transport layer. - [ActiveMQ](http://activemq.apache.org/) - Powerful open source messaging and integration patterns server. - [Aeron](https://github.com/real-logic/Aeron) - Efficient reliable UDP unicast, UDP multicast, and IPC message transport. - [Apollo](http://activemq.apache.org/apollo/) - Faster, more reliable, easier to maintain messaging broker built from the foundations of the original ActiveMQ. - [Ascoltatori](https://github.com/mcollina/ascoltatori) - Pub/sub library for Node. - [Beanstalk](http://kr.github.io/beanstalkd/) - Simple, fast work queue. - [Disque](https://github.com/antirez/disque) - Distributed message broker. - [Kafka](http://kafka.apache.org/) - Publish-subscribe messaging rethought as a distributed commit log. - [Malamute](https://github.com/zeromq/malamute) - ZeroMQ enterprise messaging broker. - [Mist](https://github.com/nanopack/mist) - A distributed, tag-based pub/sub service. - [Mosca](http://www.mosca.io/) - MQTT broker as a module. - [Mosquitto](http://mosquitto.org/) - Open source message broker that implements the MQTT protocol. - [Nanomsg](http://nanomsg.org/) - Socket library that provides several common communication patterns for building distributed systems. - [NATS](https://nats.io/) - Open source, high-performance, lightweight cloud messaging system. - [NSQ](http://nsq.io/) - A realtime distributed messaging platform. - [Qpid](https://qpid.apache.org/) - Cross-platform messaging components built on AMQP. - [RabbitMQ](https://www.rabbitmq.com/) - Open source Erlang-based message broker that just works. - [VerneMQ](https://verne.mq) - Open source, scalable, Erlang-based MQTT broker. ### Serialization - [Avro](https://avro.apache.org/) - Apache data serialization system providing rich data structures in a compact, fast, binary data format. - [BooPickle](https://github.com/ochrons/boopickle) - Binary serialization library for efficient network communication. For Scala and Scala.js - [Cap’n Proto](https://capnproto.org/) - Insanely fast data interchange format and capability-based RPC system. - [CBOR](http://cbor.io/) - Implementations of the CBOR standard (RFC 7049) in many languages. - [Cereal](http://uscilab.github.io/cereal/) - C++11 library for serialization. - [Cheshire](https://github.com/dakrone/cheshire) - Clojure JSON and JSON SMILE encoding/decoding. - [Etch](http://etch.apache.org/) - Cross-platform, language and transport-independent framework for building and consuming network services. - [Fastjson](https://github.com/alibaba/fastjson) - Fast JSON Processor. - [Ffjson](https://github.com/pquerna/ffjson) - Faster JSON serialization for Go. - [FST](https://github.com/RuedigerMoeller/fast-serialization) - Fast java serialization drop in-replacemen. - [Jackson](https://github.com/FasterXML/jackson) - A multi-purpose Java library for processing JSON data format. - [Jackson Afterburner](https://github.com/FasterXML/jackson-module-afterburner) - Jackson module that uses bytecode generation to further speed up data binding (+30-40% throughput for serialization, deserialization). - [Kryo](https://github.com/EsotericSoftware/kryo) - Java serialization and cloning: fast, efficient, automatic. - [MessagePack](http://msgpack.org/) - Efficient binary serialization format. - [Protostuff](http://www.protostuff.io/) - A serialization library with built-in support for forward-backward compatibility (schema evolution) and validation. - [SBinary](https://github.com/harrah/sbinary) - Library for describing binary formats for Scala types. - [Thrift](http://thrift.apache.org/) - The Apache Thrift software framework, for scalable cross-language services development. ### Storage - [Aerospike](http://www.aerospike.com/) - High performance NoSQL database delivering speed at scale. - [ArangoDB](https://www.arangodb.com/) - A distributed free and open source database with a flexible data model for documents, graphs, and key-values. - [AtlasDB](https://github.com/palantir/atlasdb) - Transactional layer on top of a key value store. - [ClickHouse](https://clickhouse.yandex/) - Column-oriented database management system that allows generating analytical data reports in real time. - [Couchbase](http://www.couchbase.com/) - A distributed database engineered for performance, scalability, and simplified administration. - [Crate](https://crate.io/) - Scalable SQL database with the NoSQL goodies. - [Datomic](http://www.datomic.com/) - Fully transactional, cloud-ready, distributed database. - [Druid](http://druid.io/) - Fast column-oriented distributed data store. - [Elasticsearch](https://www.elastic.co/products/elasticsearch) - Open source distributed, scalable, and highly available search server. - [Elliptics](http://reverbrain.com/elliptics/) - Fault tolerant distributed key/value storage. - [Geode](http://geode.incubator.apache.org/) - Open source, distributed, in-memory database for scale-out applications. - [Manta](https://www.joyent.com/manta) - Highly scalable, distributed object storage service with integrated compute. - [MemSQL](http://www.memsql.com/) - High-performance, in-memory database that combines the horizontal scalability of distributed systems with the familiarity of SQL. - [Parquet](https://parquet.apache.org/) - Columnar storage format available to any project in the Hadoop ecosystem, regardless of the choice of data processing framework, data model or programming language. - [Reborn](https://github.com/reborndb/reborn) - Distributed database fully compatible with redis protocol. - [RethinkDB](http://rethinkdb.com/) - Open source, scalable database that makes building realtime apps easier. - [Secure Scuttlebutt](https://github.com/ssbc/docs) - P2P database of message-feeds. - [Tachyon](http://tachyon-project.org/) - Memory-centric distributed storage system, enabling reliable data sharing at memory-speed across cluster frameworks. ### Reactivity - [Reactor.io](http://projectreactor.io) - A second-generation Reactive library for building non-blocking applications on the JVM based on the Reactive Streams Specification. - [Reactive Kafka](https://github.com/softwaremill/reactive-kafka) - Reactive Streams API for Apache Kafka. - [ReactiveX](http://reactivex.io/) - API for asynchronous programming with observable streams. Available for idiomatic Java, Scala, C#, C++, Clojure, JavaScript, Python, Groovy, JRuby, and others. - [Simple React](https://github.com/aol/simple-react) - Powerful future streams & asynchronous data structures for Java 8. ### Resilience - [Hystrix](https://github.com/Netflix/Hystrix) - Latency and fault tolerance library designed to isolate points of access to remote systems, services and 3rd party libraries, stop cascading failure and enable resilience in complex distributed systems where failure is inevitable. - [Pathod](http://pathod.net/) - Crafted malice for tormenting HTTP clients and servers. - [Raft Consensus](http://raftconsensus.github.io/) - Consensus algorithm that is designed to be easy to understand. It's equivalent to Paxos in fault-tolerance and performance. - [Resilient HTTP](http://resilient-http.github.io/) - A smart HTTP client with super powers like fault tolerance, dynamic server discovery, auto balancing and reactive recovery, designed for distributed systems. - [Saboteur](https://github.com/tomakehurst/saboteur) - Causing deliberate network mayhem for better resilience. - [Simian Army](https://github.com/Netflix/SimianArmy) - Suite of tools for keeping your cloud operating in top form. Chaos Monkey, the first member, is a resiliency tool that helps ensure that your applications can tolerate random instance failures. ### Testing - [Mitmproxy](https://mitmproxy.org/) - An interactive console program that allows traffic flows to be intercepted, inspected, modified and replayed. - [Mountebank](http://www.mbtest.org/) - Cross-platform, multi-protocol test doubles over the wire. - [Spring Cloud Contract](https://cloud.spring.io/spring-cloud-contract/) - TDD to the level of software architecture. - [VCR](https://github.com/vcr/vcr) - Record your test suite's HTTP interactions and replay them during future test runs for fast, deterministic, accurate tests. See the list of ports for implementations in other languages. - [Wilma](https://github.com/epam/Wilma) - Combined HTTP/HTTPS service stub and transparent proxy solution. - [WireMock](http://wiremock.org/) - Flexible library for stubbing and mocking web services. Unlike general purpose mocking tools it works by creating an actual HTTP server that your code under test can connect to as it would a real web service. ### Monitoring and Debugging - [Beats](https://www.elastic.co/products/beats) - Lightweight shippers for Elasticsearch & Logstash. - [Collectd](https://collectd.org/) - The system statistics collection daemon. - [Elastalert](https://github.com/yelp/elastalert) - Easy & flexible alerting for Elasticsearch. - [Ganglia](http://ganglia.info/) - A scalable distributed monitoring system for high-performance computing systems such as clusters and grids. - [Grafana](http://grafana.org/) - An open source, feature rich metrics dashboard and graph editor for Graphite, InfluxDB & OpenTSDB. - [Graphite](http://graphite.wikidot.com/) - Scalable realtime graphing. - [Parallec](https://github.com/eBay/parallec) - Fast parallel asynchronous HTTP/SSH/TCP/Ping client Java library. - [Prometheus](http://prometheus.io/) - An open source service monitoring system and time series database. - [REST Commander](https://github.com/eBay/restcommander) - Fast parallel asynchronous HTTP client as a service to monitor and manage HTTP endpoints. - [Riemann](http://riemann.io/) - Monitors distributed systems. - [Sensu](https://github.com/sensu) - Monitoring for today's infrastructure. - [Trace](https://github.com/RisingStack/trace-nodejs) - A visualised stack trace platform designed for microservices. - [Watcher](https://www.elastic.co/products/watcher) - Alerting for Elasticsearch. - [Zabbix](http://www.zabbix.com/) - Open source enterprise-class monitoring solution. - [Zipkin](http://zipkin.io) - Distributed tracing system. ### Logging - [Bunyan](https://github.com/trentm/node-bunyan) - Simple and fast JSON logging library for Node.js services. - [Fluentd](http://www.fluentd.org/) - Open source data collector for unified logging layer. - [Graylog](https://www.graylog.org/) - Fully integrated open source log management platform. - [Kibana](https://www.elastic.co/products/kibana) - Flexible analytics and visualization platform. - [Logstash](https://www.elastic.co/products/logstash) - Tool for managing events and logs. - [Suro](https://github.com/Netflix/suro/wiki) - Distributed data pipeline which enables services for moving, aggregating, routing, storing data. ## IT Automation / Provisioning - [Ansible](http://www.ansible.com/) - Radically simple IT automation platform that makes your applications and systems easier to deploy. - [Chef](https://www.chef.io/chef/) - Automate how you build, deploy, and manage your infrastructure. - [Helios](https://github.com/spotify/helios) - Docker container orchestration platform. - [Packer](https://www.packer.io/) - Tool for creating identical machine images for multiple platforms from a single source configuration. - [PM2](https://github.com/Unitech/pm2) - Production process manager for Node.js apps with a built-in load balancer. - [Puppet](https://puppetlabs.com/) - From provisioning bare metal & launching containers to new ways to manage infrastructure as code. - [Salt](https://github.com/saltstack/salt) - Infrastructure automation and management system. - [Terraform](https://www.terraform.io/) - Provides a common configuration to launch infrastructure, from physical and virtual servers to email and DNS providers. ## Deployment and Continuous Integration ### On-prem - [Buddy Go](https://buddy.works/buddy-go) - The On-Premises Git and Continuous Integration Platform - [Drone](https://github.com/drone/drone) - Drone is a continuous delivery platform built on Docker, written in Go. - [ION-Roller](https://github.com/gilt/ionroller) - AWS immutable deployment framework for web services. - [Janky](https://github.com/github/janky) - Continuous integration server built on top of Jenkins and Hubot. - [Jenkins](http://jenkins-ci.org/) - Extensible open source continuous integration server. - [Nscale](https://github.com/nearform/nscale) - Open toolkit supporting configuration, build and deployment of connected container sets. - [Project 6](https://github.com/DatawiseIO/Project6) - Software for deploying and managing Docker containers across a cluster of hosts, with a focus on simplifying network and storage configurations for on-premises environments. - [Puller](https://github.com/crufter/puller) - A very simple, distributed tool to deploy and do CI with Docker containers. - [Rancher](https://github.com/rancher/rancher) - Open source platform for operating Docker in production. - [Spinnaker](https://github.com/spinnaker/spinnaker) - Open source cloud-agnostic continuous delivery and infrastructure management platform. ### Hosted - [AWS CodeDeploy](http://aws.amazon.com/codedeploy/) - Deployment service that enables developers to automate the deployment of applications to instances and to update the applications as required. - [AWS OpsWorks](http://aws.amazon.com/opsworks/) - Provides a simple and flexible way to create and manage stacks and applications. - [Buddy](https://buddy.works/) - The Git and Continuous Delivery Platform. - [Codeship](https://codeship.com/) - Hosted continuous delivery platform that takes care of the testing and deployment process. - [Semaphore](https://semaphoreci.com/) - Continuous integration and deployment service with native Docker support. - [Travis](https://travis-ci.org/) - Continuous integration and deployment service. ### Lightweight - [Capsule](https://github.com/puniverse/capsule) - Packaging and deployment tool for JVM applications. - [Fleet](https://github.com/substack/fleet) - Multi-server continuous git-based deployment and process management. - [Kafka Deploy](https://github.com/nathanmarz/kafka-deploy) - Automated deploy for a Kafka cluster on AWS. - [LambdaCD](https://github.com/flosell/lambdacd) - A library to define a continuous delivery pipeline in code. ## Containers - [AWS ECS](http://aws.amazon.com/ecs/) - Easily run and manage Docker-enabled applications across a cluster of Amazon EC2 instances. - [CoreOS](https://coreos.com/) - Open source lightweight operating system based on the Linux kernel and designed for providing infrastructure to clustered deployments. - [DC/OS](https://dcos.io/) - Open source orchestration system (built on top of Mesos and Marathon) for automatically distributing and running containers on several computers. - [Docker](https://www.docker.com/) - Open platform for distributed applications for developers and sysadmins. - [Kubernetes](http://kubernetes.io/) - Open source orchestration system for Docker containers. - [Linux Containers](https://linuxcontainers.org/) - The umbrella project behind LXC, LXD, LXCFS and CGManager. - [RancherOS](https://github.com/rancher/os) - The smallest, easiest way to run Docker in production at scale. ## Documentation & Modeling ### REST APIs - [Aglio](https://github.com/danielgtaylor/aglio) - API Blueprint renderer with theme support that outputs static HTML. - [API Blueprint](https://apiblueprint.org/) - Tools for your whole API lifecycle. Use it to discuss your API with others. Generate documentation automatically. Or a test suite. Or even some code. - [Apidoc](https://github.com/mbryzek/apidoc) - Beautiful documentation for REST services. - [RAML](http://raml.org/) - RESTful API Modeling Language, a simple and succinct way of describing practically-RESTful APIs. - [Slate](https://github.com/tripit/slate) - Beautiful static documentation for your API. - [Spring REST Docs](http://projects.spring.io/spring-restdocs/) - Document RESTful services by combining hand-written documentation with auto-generated snippets produced with Spring MVC Test. - [Swagger](http://swagger.io/) - A simple yet powerful representation of your RESTful API. ## Standards / Recommendations ### World Wide Web - [W3C.REC-Webarch](http://www.w3.org/TR/webarch/) - Architecture of the World Wide Web, Volume One. - [RFC3986](https://tools.ietf.org/html/rfc3986) - Uniform Resource Identifier (URI): Generic Syntax. - [RFC6570](https://tools.ietf.org/html/rfc6570) - URI Template. - [RFC7320](https://tools.ietf.org/html/rfc7320) - URI Design and Ownership. ### HTTP/1.1 - [RFC7230](https://tools.ietf.org/html/rfc7230) - Message Syntax and Routing. - [RFC7231](https://tools.ietf.org/html/rfc7231) - Semantics and Content. - [RFC7232](https://tools.ietf.org/html/rfc7232) - Conditional Requests. - [RFC7233](https://tools.ietf.org/html/rfc7233) - Range Requests. - [RFC7234](https://tools.ietf.org/html/rfc7234) - Caching. - [RFC7235](https://tools.ietf.org/html/rfc7235) - Authentication. ### HTTP/2 - [RFC7540](https://tools.ietf.org/html/rfc7540) - Hypertext Transfer Protocol Version 2. ### CoAP - [RFC7252](http://coap.technology/spec.html) - The Constrained Application Protocol (CoAP) is a specialized web transfer protocol for use with constrained nodes and constrained networks in the Internet of Things. ### RPC - [BERT-RPC 1.0](http://bert-rpc.org/) - An attempt to specify a flexible binary serialization and RPC protocol that are compatible with the philosophies of dynamic languages. - [JSON-RPC 2.0](http://www.jsonrpc.org/specification) - A stateless, light-weight remote procedure call (RPC) protocol. ### Messaging - [AMQP](http://www.amqp.org/) - Advanced Message Queuing Protocol. - [MQTT](http://mqtt.org/) - MQ Telemetry Transport. - [STOMP](https://stomp.github.io/) - Simple Text Oriented Messaging Protocol. ### Security - [RFC5246](https://tools.ietf.org/html/rfc5246) - The Transport Layer Security (TLS) Protocol Version 1.2. - [RFC6066](https://tools.ietf.org/html/rfc6066) - TLS Extensions. - [RFC6347](https://tools.ietf.org/html/rfc6347) - Datagram Transport Layer Security Version 1.2. - [RFC6749](https://tools.ietf.org/html/rfc6749) - The OAuth 2.0 authorization framework. - [RFC7515](https://tools.ietf.org/html/rfc7515) - JSON Web Signature (JWS) represents content secured with digital signatures or Message Authentication Codes (MACs) using JSON-based data structures. - [RFC7519](https://tools.ietf.org/html/rfc7519) - JSON Web Token (JWT) is a compact, URL-safe means of representing claims to be transferred between two parties. - [RFC7642](https://tools.ietf.org/html/rfc7642) - SCIM: Definitions, overview, concepts, and requirements. - [RFC7643](https://tools.ietf.org/html/rfc7643) - SCIM: Core Schema, provides a platform-neutral schema and extension model for representing users and groups. - [RFC7644](https://tools.ietf.org/html/rfc7644) - SCIM: Protocol, an application-level, REST protocol for provisioning and managing identity data on the web. - [OIDCONN](http://openid.net/connect/) - OpenID Connect 1.0 is a simple identity layer on top of the OAuth 2.0 protocol. It allows clients to verify the identity of the end-user based on the authentication performed by an Authorization Server, as well as to obtain basic profile information about the end-user in an interoperable and REST-like manner. ### Service Discovery - [HAL](https://tools.ietf.org/html/draft-kelly-json-hal-07) - The JSON Hypertext Application Language (HAL) is a standard which establishes conventions for expressing hypermedia controls, such as links, with JSON. DRAFT - [Hydra](http://www.hydra-cg.com/) - Specifications for interoperable, hypermedia-driven Web APIs. - [GraphQL](http://graphql.org/) - Query language designed to build client applications by providing an intuitive and flexible syntax and system for describing their data requirements and interactions. DRAFT - [WADL](http://www.w3.org/Submission/wadl/) - The Web Application Description Language specification. - [WSDL](http://www.w3.org/TR/wsdl20/) - The Web Services Description Language Version 2.0 spec. ### Data Formats - [RFC4627](https://tools.ietf.org/html/rfc4627) - JavaScript Object Notation (JSON). - [RFC7049](http://tools.ietf.org/search/rfc7049) - Concise Binary Object Representation (CBOR). - [BSON](http://bsonspec.org/) - Binary JSON (BSON). - [JSON-LD](http://json-ld.org/) - JSON for Linking Data. - [SBE](https://github.com/FIXTradingCommunity/fix-simple-binary-encoding) - Simple Binary Encoding (SBE). - [MSGPACK](https://github.com/msgpack/msgpack/blob/master/spec.md) - MessagePack Specification. - [UBJSON](http://ubjson.org/) - Universal Binary JSON Specification. ### Vocabularies - [JSON Schema](http://json-schema.org/) - Vocabulary that allows you to annotate and validate JSON documents. - [LOV](http://lov.okfn.org/) - Linked open vocabularies. - [Schema.org](http://schema.org/) - Collaborative, community activity with a mission to create, maintain, and promote schemas for structured data on the Internet, on web pages, in email messages, and beyond. ### Unicode - [UNIV8](http://www.unicode.org/versions/Unicode8.0.0/) - The Unicode Consortium. The Unicode Standard, Version 8.0.0, (Mountain View, CA: The Unicode Consortium, 2015. ISBN 978-1-936213-10-8). - [RFC3629](https://tools.ietf.org/html/rfc3629) - UTF-8, a transformation format of ISO 10646. ## Real Life Stories - [A Journey into Microservices](https://sudo.hailoapp.com/services/2015/03/09/journey-into-a-microservice-world-part-1/) - [Clean microservice architecture](http://blog.cleancoder.com/uncle-bob/2014/10/01/CleanMicroserviceArchitecture.html) - [Failing at microservices](https://rclayton.silvrback.com/failing-at-microservices) - [How to talk to your friends about microservices](https://blog.pivotal.io/labs/labs/how-to-talk-to-your-friends-about-microservices) - [How we build microservices at Karma](https://blog.yourkarma.com/building-microservices-at-karma) - [How we ended up with microservices at SoundCloud](http://philcalcado.com/2015/09/08/how_we_ended_up_with_microservices.html) - [Microservices: lessons from the frontline](https://www.thoughtworks.com/insights/blog/microservices-lessons-frontline) - [Monolith first](http://martinfowler.com/bliki/MonolithFirst.html) - [Scaling microservices at Gilt with Scala, Docker and AWS](http://www.infoq.com/news/2015/04/scaling-microservices-gilt) ## Enterprise & Verticals - [Interact](https://interact.io/) - CRM microservices for rapid delivery of tailored solutions. - [Predix](https://predix.io/) - Industrial microservices platform. ## Theory ### Articles & Papers - [AKF Scale Cube](http://akfpartners.com/techblog/2008/05/08/splitting-applications-or-services-for-scale/) - Model depicting the dimensions to scale a service. - [Benchmark Requirements for Microservices Architecture Research](https://goo.gl/14ElnV) :small_orange_diamond:PDF - Set of requirements that may be useful in selecting a community-owned architecture benchmark to support repeatable microservices research. - [Building Microservices? Here is What You Should Know](https://cloudncode.blog/2016/07/22/msa-getting-started/) - A practical overview, based on real-world experience, of what one would need to know in order to build Microservices. - [CALM](http://db.cs.berkeley.edu/papers/cidr11-bloom.pdf) :small_orange_diamond:PDF - Consistency as logical monotonicity. - [Canary Release](http://martinfowler.com/bliki/CanaryRelease.html) - Technique to reduce the risk of introducing a new software version in production by slowly rolling out the change to a small subset of users before rolling it out to the entire infrastructure and making it available to everybody. - [CAP Theorem](http://blog.thislongrun.com/2015/03/the-cap-theorem-series.html) - States that it is impossible for a distributed computer system to simultaneously provide all three of the following guarantees: Consistency, Availability and Partition tolerance. - [Cloud Design Patterns](https://msdn.microsoft.com/en-us/library/dn600223.aspx) - Contains twenty-four design patterns that are useful in cloud-hosted applications. Includes: Circuit Breaker, Competing Consumers, CQRS, Event Sourcing, Gatekeeper, Cache-Aside, etc. - [Hexagonal Architecture](http://alistair.cockburn.us/Hexagonal+architecture) - Allows an application to equally be driven by users, programs, automated test or batch scripts, and to be developed and tested in isolation from its eventual run-time devices and databases. - [Microservice Architecture](http://martinfowler.com/articles/microservices.html) - Particular way of designing software applications as suites of independently deployable services. - [Microservices and SOA](http://www.oracle.com/technetwork/issue-archive/2015/15-mar/o25architect-2458702.html) - Similarities, differences, and where we go from here. - [Microservices – Please, don’t](http://basho.com/posts/technical/microservices-please-dont/) - Critical advice about some problems regarding a microservices approach. - [Microservices RefCard](https://dzone.com/refcardz/getting-started-with-microservices) - Getting started with microservices. - [Microservices Trade-Offs](http://martinfowler.com/articles/microservice-trade-offs.html) - Guide to ponder costs and benefits of the mircoservices architectural style. - [Reactive Manifesto](http://www.reactivemanifesto.org/) - Reactive systems definition. - [Reactive Streams](http://www.reactive-streams.org/) - Initiative to provide a standard for asynchronous stream processing with non-blocking back pressure. - [ROCAS](http://resources.1060research.com/docs/2015/Resource-Oriented-Computing-Adaptive-Systems-ROCAS-1.2.pdf) :small_orange_diamond:PDF - Resource Oriented Computing for Adaptive Systems. - [SECO](http://ceur-ws.org/Vol-746/IWSECO2011-6-DengYu.pdf) :small_orange_diamond:PDF - Understanding software ecosystems: a strategic modeling approach. - [Service Discovery in a Microservice Architecture](https://www.nginx.com/blog/service-discovery-in-a-microservices-architecture/) - Overview of discovery and registration patterns. - [Testing Strategies in a Microservice Architecture](http://martinfowler.com/articles/microservice-testing/) - Approaches for managing the additional testing complexity of multiple independently deployable components. - [Your Server as a Function](http://monkey.org/~marius/funsrv.pdf) :small_orange_diamond:PDF - Describes three abstractions which combine to present a powerful programming model for building safe, modular, and efficient server software: Composable futures, services and filters. ### Talks - [Bla Bla Microservices Bla Bla](http://jonasboner.com/bla-bla-microservices-bla-bla/) - A talk at the O’Reilly Software Architecture Conference, April 2016. - [Challenges in Implementing MicroServices](https://www.youtube.com/watch?v=yPf5MfOZPY0) - A presentation at GOTO 2015 by Fred George. - [Microservices](https://www.youtube.com/watch?v=wgdBVIX9ifA) - A presentation at GOTO Berlin 2014 by Martin Fowler. ### Tutorials - [Developing a RESTful Microservice in Python](http://www.skybert.net/python/developing-a-restful-micro-service-in-python/) - A story of how an aging Java project was replaced with a microservice built with Python and Flask. - [Developing and Testing Microservices With Docker](http://mherman.org/blog/2017/04/18/developing-and-testing-microservices-with-docker) - An example of the processes involved in creating a simple Docker-packaged Node microservice. - [Game On!](https://game-on.org/) - Microservices architecture explained in the context of an old-school text-based adventure game. - [Microservices without the Servers](https://aws.amazon.com/blogs/compute/microservices-without-the-servers/) - Step by step demo-driven talk about serverless architecture. - Microservices in C#: [Part 1](http://insidethecpu.com/2015/07/17/microservices-in-c-part-1-building-and-testing/), [Part 2](http://insidethecpu.com/2015/07/31/microservices-in-c-part-2-consistent-message-delivery/), [Part 3](http://insidethecpu.com/2015/08/14/microservices-in-c-part-3-queue-pool-sizing/), [Part 4](http://insidethecpu.com/2015/08/28/microservices-in-c-part-4-scaling-out/), [Part 5](http://insidethecpu.com/2015/09/11/microservices-in-c-part-5-autoscaling/). - [Microservices with Python, RabbitMQ and Nameko](http://brunorocha.org/python/microservices-with-python-rabbitmq-and-nameko.html) - [Reactive Microservices](https://github.com/theiterators/reactive-microservices) - Project showcasing different microservice communication styles using Scala, Akka, Play and other tools from Scala ecosystem. - [Using Packer and Ansible to build immutable infrastructure](https://blog.codeship.com/packer-ansible/) ### Books - [Building Microservices](https://www.nginx.com/wp-content/uploads/2015/01/Building_Microservices_Nginx.pdf) :small_orange_diamond:PDF - Building Microservices: Designing Fine-grained Systems. Sam Newman. Preview Edition. - [Microservice Architecture: Aligning Principles, Practices, and Culture](http://shop.oreilly.com/product/0636920050308.do) - Practical advice for the strategy and design of Microservices. - [Microservice Patterns](https://www.manning.com/books/microservice-patterns) - Teaches how to build applications with the microservice architecture and how to refactor a monolithic application to a microservices. - [Microservices from Theory to Practice](http://www.redbooks.ibm.com/abstracts/sg248275.html?Open) - Microservices from Theory to Practice: Creating Applications in IBM Bluemix Using the Microservices Approach. IBM Redbooks publication. - [Migrating to Cloud Native Application Architectures](http://pivotal.io/platform/migrating-to-cloud-native-application-architectures-ebook) - This O’Reilly report defines the unique characteristics of cloud native application architectures such as microservices and twelve-factor applications. - [Testing Microservices with Mountebank](https://www.manning.com/books/testing-microservices-with-mountebank) - Provides a testing strategy using mountebank for service virtualization, promoting independent releases of Microservices - [The Art of Scalability](http://theartofscalability.com/) - The Art of Scalability: Scalable Web Architecture, Processes, and Organizations for the Modern Enterprise. Martin L. Abbott, Michael T. Fisher. - [The New Stack eBook Series](http://thenewstack.io/ebookseries/) - A Comprehensive Overview of the Docker and Container Ecosystem. + Book 1: The Docker Container Ecosystem. + Book 2: Applications & Microservices with Docker & Containers. + Book 3: Automation & Orchestration with Docker & Containers. + Book 4: Network, Security & Storage with Docker & Containers. + Book 5: Monitoring & Management with Docker & Containers. - [The Tao of Microservices](https://www.manning.com/books/the-tao-of-microservices) - Teaches the path to understanding how to apply microservices architecture with your own real-world projects. ### Sites - [Microservices Resource Guide](http://martinfowler.com/microservices/) - Martin Fowler's choice of articles, videos, books, and podcasts that can teach you more about the microservices architectural style. - [Microservice Patterns](http://microservices.io/) - Microservice architecture patterns and best practices. - [Microservice Antipatterns and Pitfalls](https://www.oreilly.com/ideas/microservices-antipatterns-and-pitfalls) - Microservice mostly known antipatterns and pitfalls. - [The 12-Factors App](http://12factor.net) - A methodology for building software-as-a-service applications. ## Emerging Technologies - [Blockchain ID](https://github.com/blockstack/blockchain-id/wiki) - A unique identifier that is secured by a blockchain. Blockchain IDs are simultaneously secure, human-meaningful, and decentralized, thereby squaring Zooko's triangle. - [Blocknet](http://blocknet.co/) - The Blocknet makes possible to deliver microservices over a blockchain-based P2P network architecture. - [CEPTR](http://ceptr.org/) - A recomposable medium for distributed social computing, a semantic self-describing protocol stack, and a cretor of fractal coherence contexts for biomimetic computing. - [Edgware Fabric](http://edgware-fabric.org/) - Lightweight, agile service bus for systems at the edge of the network, in the physical world. - [MultiChain](http://www.multichain.com/) - Open platform for building blockchains. - [Node-RED](http://nodered.org/) - Visual tool for wiring together hardware devices, APIs and online services in new and interesting ways. - [Pony](http://www.ponylang.org/) - Open source, object-oriented, actor-model, capabilities-secure, high performance programming language. ## License [![CC0](http://i.creativecommons.org/p/zero/1.0/88x31.png)](http://creativecommons.org/publicdomain/zero/1.0/) ## Contributing Please, read the [Contribution Guidelines](https://github.com/mfornos/awesome-microservices/blob/master/CONTRIBUTING.md) before submitting your suggestion. Feel free to [open an issue](https://github.com/mfornos/awesome-microservices/issues) or [create a pull request](https://github.com/mfornos/awesome-microservices/pulls) with your additions. :star2: Thank you!