awesome-microservices

A curated list of Microservice Architecture related principles and technologies.

GitHub

13k stars
624 watching
2k forks
last commit: about 2 months ago
Linked from 7 awesome lists

awesomecloud-computingcloud-nativemicroservicesmicroservices-architecture

Awesome Microservices / Platforms

Jolie Open source microservice-oriented programming language
Kalix (c) Platform as a Service that abstracts away the complexity of event-driven microservices
Lightbend (c) Platform for building scalable reactive systems on the JVM
OpenWhisk Serverless, open source cloud platform that executes functions in response to events at any scale
Pulumi SDK for cloud native infrastructure as code. Use your favorite language to preview and manage updates to your apps and infrastructure, and continuously deploy to any cloud (no YAML required)
Triton 1,311 about 1 month ago Open-source cloud management platform that delivers next generation, container-based, service-oriented infrastructure across one or more data centers
Wing Cloud-oriented programming language. It allows developers to build distributed systems that fully leverage the power of the cloud without having to worry about the underlying infrastructure

Awesome Microservices / Frameworks / Runtimes

Akka Toolkit and runtime for building highly concurrent, distributed, and resilient message-driven applications on the JVM
Axon (c) An end-to-end development and infrastructure platform for easy development and running of any DDD, CQRS and Event Sourcing applications on JVM
Ballerina Cloud native programming language
Bun Fast all-in-one JavaScript runtime
Dapr Open source runtime for writing highly performant microservices using any programming language
Deno JavaScript, TypeScript, and WebAssembly runtime with secure defaults and a great developer experience
Eclipse Microprofile An open forum to optimize Enterprise Java for a microservices architecture by innovating across multiple implementations and collaborating on common areas of interest with a goal of standardization
Erlang/OTP 11,319 4 days ago Programming language used to build massively scalable soft real-time systems with requirements on high availability
Finagle Extensible RPC system for the JVM, used to construct high-concurrency servers
Gleam A friendly language for building type-safe, scalable systems
GraalVM High-performance runtime that provides significant improvements in application performance and efficiency which is ideal for microservices
Helidon Collection of Java libraries for writing microservices that run on a fast web core powered by Netty
Ice Comprehensive RPC framework with support for C++, C#, Java, JavaScript, Python, and more
Light-4j 3,608 8 days ago A high throughput, low latency, small memory footprint and more productive microservices platform
Micronaut A modern, JVM-based, full-stack framework for building modular, easily testable microservice applications
Moleculer Fast & powerful microservices framework for Node.js, Java, Go and Ruby
Open Liberty A lightweight open framework for building fast and efficient cloud-native Java microservices
Orbit 1,703 over 3 years ago Modern framework for JVM languages that makes it easier to build and maintain distributed and scalable online services
SmallRye APIs and implementations tailored for cloud development, including Eclipse MicroProfile
Spin 5,163 11 days ago An open source framework for building and running fast, secure, and composable cloud microservices with WebAssembly
ScaleCube 610 11 days ago Toolkit for building reactive microservices for the JVM: low-latency, high-throughput, scalable and resilient
Vert.X Toolkit for building reactive applications on the JVM
Vert.X Toolbox 114 18 days ago A set of Vert.x components to build reactive microservice applications
Wangle 3,050 12 days ago A framework providing a set of common client/server abstractions for building services in a consistent, modular, and composable way

Awesome Microservices / Service Toolkits / Polyglot

GRPC 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 A very newbility RPC Library, support 25+ languages now

Awesome Microservices / Service Toolkits / C

Kore Easy to use web application framework for writing scalable web APIs in C
Libasyncd 174 10 months ago Embeddable event-based asynchronous HTTP server library for C
Libslack 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 High-performance and scalable web server
Onion 2,014 almost 2 years ago C library to create simple HTTP servers and web applications

Awesome Microservices / Service Toolkits / C++

Cap’n Proto RPC The Cap’n Proto C++ RPC implementation
C++ Micro Services 810 12 days ago An OSGi-like C++ dynamic module system and service registry
Enduro/X 126 14 days ago XATMI based service framework for GNU/Linux
Pistache 3,170 12 days ago A high-performance REST toolkit written in C++
Poco C++ class libraries for building network-based applications and servers
Sogou Workflow 12,987 11 days ago Enterprise-grade programming engine aimed to satisfy most of the backend development requirements

Awesome Microservices / Service Toolkits / CSharp

Awesome Microservices .NET Core 2,741 about 2 months ago A collection of awesome training series, articles, videos, books, courses, sample projects, and tools for microservices in .NET Core
Akka.NET Toolkit and runtime for building highly concurrent, distributed, and fault tolerant event-driven applications on .NET & Mono
Orleans Provides a straightforward approach to building distributed high-scale computing applications, without the need to learn and apply complex concurrency or other scaling patterns

Awesome Microservices / Service Toolkits / D

Vibe.d Asynchronous I/O that doesn’t get in your way, written in D

Awesome Microservices / Service Toolkits / Erlang VM

Phoenix Framework for building HTML5 apps, API backends and distributed systems
Plug 2,844 16 days ago A specification and conveniences for composable modules between web applications
Cowboy 7,273 3 months ago Small, fast, modular HTTP server written in Erlang
Mochiweb 1,865 7 months ago Erlang library for building lightweight HTTP servers

Awesome Microservices / Service Toolkits / Go

Chi 18,281 9 days ago Lightweight, idiomatic and composable router for building Go HTTP services
Echo Fast and unfancy HTTP server framework for Go. Up to 10x faster than the rest
Fiber 33,388 3 days ago Express inspired web framework built on top of Fasthttp, the fastest HTTP engine for Go. Designed to ease things up for fast development with zero memory allocation and performance in mind
Gin 78,246 12 days ago Gin is a HTTP web framework written in Go (Golang). It features a Martini-like API with much better performance, up to 40 times faster
Goa 5,654 12 days ago Design-based HTTP microservices in Go
GoFr 2,839 1 day ago An opinionated microservice development framework emphasizing scalability and robustness. Designed to simplify the development of microservices
Go Chassis 2,732 25 days ago A framework for rapid development of microservices in Go that is easy to integrate with some cloud ecosystems
Go kit 26,527 3 months ago Distributed programming toolkit for microservices in the modern enterprise
Go-micro 21,846 about 1 month ago A distributed systems development framework
go-zero 28,997 11 days ago A web and rpc distributed system development framework
Gorilla Web toolkit for the Go programming language
Iris 25,181 9 days ago Fast, simple and efficient micro web framework for Go
Lura 6,310 3 months ago Framework to build ultra performance API Gateways with middlewares
Micro 12,101 18 days ago A distributed systems runtime for the cloud and beyond
Negroni 7,452 4 months ago Idiomatic HTTP middleware for Golang
RPCX 8,088 18 days ago A distributed RPC service framework based on NET/RPC like Alibaba Dubbo and Weibo Motan

Awesome Microservices / Service Toolkits / Haskell

Scotty 1,716 3 months ago Micro web framework inspired by Ruby's Sinatra, using WAI and Warp
Servant 1,817 23 days ago Type-level web DSL
Yesod 2,626 about 1 month ago The Haskell RESTful web framework

Awesome Microservices / Service Toolkits / Java VM

Compojure 4,084 8 months ago A concise routing library for Ring/Clojure
Duct 1,127 over 3 years ago Minimal framework for building web applications in Clojure, with a strong emphasis on simplicity
System 607 11 days ago Built on top of Stuart Sierra's component library, offers a set of readymade components
Tesla 190 4 months ago Common basis for some of Otto.de's Clojure microservices
ActiveRPC Lightweight and fast library for complex high-load distributed applications and Memcached-like solutions
Airlift 584 4 days ago Framework for building REST services in Java
Armeria Open-source asynchronous HTTP/2 RPC/REST client/server library built on top of Java 8, Netty, Thrift and gRPC
Disruptor 17,382 22 days ago High-performance inter-thread messaging library
Dropwizard Java framework for developing ops-friendly, high-performance, RESTful web services
Dubbo 40,411 3 days ago A high-performance, java based RPC framework open-sourced by Alibaba
Conjure 80 8 days ago Opinionated set of 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 690 15 days ago RESTful services in Java. JAX-RS reference implementation
Quarkus A Kubernetes Native Java stack tailored for OpenJDK HotSpot and GraalVM, crafted from the best of breed Java libraries and standards
Ratpack Set of Java libraries that facilitate fast, efficient, evolvable and well tested HTTP applications. specific support for the Groovy language is provided
Spring Boot Makes it easy to create stand-alone, production-grade Spring based applications
Http4k Lightweight but fully-featured HTTP toolkit written in pure Kotlin that enables the serving and consuming of HTTP services in a functional and consistent way
Ktor Framework for building asynchronous servers and clients in connected systems using the Kotlin programming language
Finatra Fast, testable, Scala HTTP services built on Twitter-Server and Finagle
Http4s A minimal, idiomatic Scala interface for HTTP
Play The high velocity web framework for Java and Scala
Squbs A suite of components enabling standardization and operationalization of Akka and Akka HTTP applications/services in a large scale, managed, cloud environment

Awesome Microservices / Service Toolkits / Node.js

Actionhero Multi-transport Node.js API server with integrated cluster capabilities and delayed tasks
Express Fast, unopinionated, minimalist web framework for Node.js
Fastify Fastify, Fast and low overhead web framework, for Node.js
FeathersJS An open source REST and realtime API layer for modern applications
Hono Small, simple, and ultrafast web framework for the Edges. It works on any JavaScript runtime
Koa Next generation web framework for Node.js
Loopback Node.js framework for creating APIs and easily connecting to backend data sources
Micro Asynchronous HTTP microservices
NestJS A Node.js framework for building efficient and scalable server-side applications with a built-in microservices support
Seneca 3,955 23 days ago A microservices toolkit for Node.js
Serverless 46,395 4 days ago Build and maintain web, mobile and IoT applications running on AWS Lambda and API Gateway (formerly known as JAWS)
tRPC 34,565 1 day ago End-to-end typesafe APIs

Awesome Microservices / Service Toolkits / Perl

Cro Libraries for creating reactive distributed systems using Perl 6
Mojolicious Next generation web framework for Perl

Awesome Microservices / Service Toolkits / PHP

API Platform API-first web framework on top of Symfony with JSON-LD, Schema.org and Hydra support
Ecotone Framework based on architectural principles of DDD, CQRS and Event Sourcing that provides building blocks to create scalable and extensible applications
Hyperf 6,181 9 days ago Hyperf is an extremely performant and flexible PHP CLI framework based on Swoole 4.5+, powered by the state-of-the-art coroutine server and a large number of battle-tested components
Lumen Stunningly fast micro-framework
Phalcon Full-stack PHP framework delivered as a C-extension
Slim Micro-framework that helps you quickly write simple yet powerful web applications and APIs
Spiral Framework designed for long-running applications using . It offers advanced features like integration with the workflow engine and websocket server. It is particularly effective for microservices architecture, providing robust support for REST APIs and gRPC services
Swoft 5,582 over 1 year ago PHP microservices coroutine framework for building high-performance web systems, APIs, middleware, and basic services
Symfony Micro-framework based on the Symfony components

Awesome Microservices / Service Toolkits / Python

Aiohttp 15,029 3 days ago HTTP client/server for asyncio
Bottle Fast, simple and lightweight WSGI micro web-framework for Python
Connexion 4,475 2 months ago Swagger/OpenAPI framework for Python on top of Flask with automatic endpoint validation and OAuth2 support
Falcon Bare-metal Python web API framework for building very fast app backends and microservices
FastAPI Modern, fast (high-performance), web framework for building APIs with Python 3.6+ based on standard Python type hints
Flask Python framework for microservices based on Werkzeug and Jinja 2
Nameko 4,703 5 months ago Python framework for building microservices
Sanic 18,026 2 months ago Sanic is a Flask-like Python 3.5+ web server that's written to go fast
Tornado Web framework and asynchronous networking library
Twisted Event-driven network programming engine
Web.py 5,885 about 2 months ago Minimalist web framework for Python

Awesome Microservices / Service Toolkits / Ruby

Grape 9,879 20 days ago An opinionated framework for creating REST-like APIs
Hanami A modern web framework for Ruby
Praxis 299 4 months ago Framework for both designing and implementing APIs
Scorched 275 over 1 year ago Light-weight web framework for Ruby
Sinatra Sinatra is a DSL for quickly creating web applications in Ruby with minimal effort

Awesome Microservices / Service Toolkits / Rust

Are we web yet? A summary of the current state of web programming in Rust
Actix Powerful, pragmatic, and extremely fast web framework for Rust
Tarpc 3,177 26 days ago RPC framework for Rust with a focus on ease of use
Tower 3,476 30 days ago Library of modular and reusable components for building robust networking clients and servers
Wtx 141 4 days ago HTTP/2 client/server framework

Awesome Microservices / Frontend / UI

Awesome Micro Frontends 567 almost 3 years ago A curated list of resources about Micro Frontends
Electrode Universal React/Node.js application platform
Micro Frontends Extending the microservice idea to frontend development
MiniApp White Paper MiniApp standardization white paper

Awesome Microservices / Capabilities / API Gateways / Edge Services

Ambassador (c) Kubernetes-native API gateway for microservices built on Envoy
APIcast 305 5 days ago APIcast is an API gateway built on top of NGINX. It is part of the Red Hat 3scale API Management Platform
Bunker Web 6,210 11 days ago Web app hosting and reverse proxy secure by default
Caddy Extensible HTTP/2 web server with automatic HTTPS
Camel 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 24,782 8 days ago Open source edge and service proxy, from the developers at Lyft
HAProxy 4,854 10 days ago Reliable, high Performance TCP/HTTP load balancer
Istio An open platform to connect, manage, and secure microservices
Keepalived Simple and robust facilities for loadbalancing and high-availability to Linux system and Linux based infrastructures
Kong 38,976 3 days ago Open source management layer for APIs
KrakenD Open source ultra performance API Gateway
Kuma Platform agnostic open source control plane for service mesh and microservices
Linkerd Resilient service mesh for cloud native apps
Neutrino 311 over 6 years ago Extensible software load balancer
OpenResty Fast web application server built on top of Nginx
Open Service Mesh Lightweight and extensible cloud native service mesh
Otoroshi Modern HTTP reverse proxy with lightweight API management
Pingora 21,405 12 days ago A library for building fast, reliable and evolvable network services
Skipper 3,086 8 days ago HTTP router useful for decoupling routing from service logic
Spring Cloud Gateway API Gateway on top of Spring MVC. Aims to provide a simple, yet effective way to route to APIs
Tengine A distribution of Nginx with some advanced features
Træfɪk A modern HTTP reverse proxy and load balancer made to deploy microservices with ease
Traffic Server 1,803 12 days ago High-performance building block for cloud services
Tyk Open source, fast and scalable API gateway, portal and API management platform
Vulcand 3,080 2 months ago Programmatic load balancer backed by Etcd
Zuul 13,458 4 days ago An edge service that provides dynamic routing, monitoring, resiliency, security, and more

Awesome Microservices / Capabilities / Configuration & Discovery

Central Dogma Open-source highly-available version-controlled service configuration repository based on Git, ZooKeeper and HTTP/2
Consul Service discovery and configuration made easy. Distributed, highly available, and datacenter-aware
Etcd 47,457 11 days ago Highly-available key-value store for shared configuration and service discovery
Eureka 12,385 about 1 month ago 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
Microconfig Modern and simple way of microservice configuration management
Nacos 30,104 5 days ago Easy-to-use dynamic service discovery, configuration and service management platform
SkyDNS 2,199 over 3 years ago Distributed service for announcement and discovery of services built on top of etcd. It utilizes DNS queries to discover available services
Spring Cloud Config Provides server and client-side support for externalized configuration in a distributed system
ZooKeeper Open source server which enables highly reliable distributed coordination

Awesome Microservices / Capabilities / Coordination & Governance

AWS Step Functions (c) Coordinate the components of distributed applications and microservices using visual workflows
Cadence Fault-oblivious stateful code platform
Conductor 12,826 10 months ago A microservices orchestration engine
Kestra 8,271 8 days ago Open source microservices event-driven, language-agnostic orchestration and scheduling platform
Temporal 11,545 3 days ago Open source microservices orchestration platform for running mission critical code at any scale
Zeebe Define, orchestrate, and monitor business processes across microservices

Awesome Microservices / Capabilities / Elasticity

Hazelcast 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 Generic cluster management framework used for the automatic management of partitioned, replicated and distributed resources hosted on a cluster of nodes
Ignite 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
Libp2p A framework and suite of protocols for building peer-to-peer network applications
Mesos 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 Distributed, highly available, datacenter-aware scheduler
Redisson 23,230 8 days ago Distributed and scalable Java data structures on top of Redis server
Serf Decentralized solution for cluster membership, failure detection and orchestration
Valkey 16,293 8 days ago A new project to resume development on the formerly open-source Redis project
Zenoh Pub/sub/query protocol unifying data in motion, data at rest and computations. Efficiently blends traditional pub/sub with geo distributed storage, queries and computations

Awesome Microservices / Capabilities / Job Schedulers / Workload Automation

Celery 24,544 11 days ago Asynchronous task queue/job queue based on distributed message passing. Focused on real-time operation and supports scheduling
Dkron Distributed, fault tolerant job scheduling system
Faktory 5,731 24 days ago Language-agnostic persistent background job server
Rundeck (c) Job scheduler and runbook automation. Enable self-service access to existing scripts and tools
Schedulix 120 3 months ago Open source enterprise job scheduling system lays down ground-breaking standards for the professional automation of IT processes in advanced system environments

Awesome Microservices / Capabilities / Logging

Fluentd Open source data collector for unified logging layer
Graylog Fully integrated open source log management platform
Kibana Flexible analytics and visualization platform
LogDNA (c) Centralized log management software. Instantly collect, centralize, and analyze logs in real-time from any platform, at any volume
Logstash Tool for managing events and logs
Loki 23,418 11 days ago Like Prometheus, but for logs

Awesome Microservices / Capabilities / Messaging

ØMQ Brokerless intelligent transport layer
ActiveMQ Powerful open source messaging and integration patterns server
Aeron 7,338 4 days ago Efficient reliable UDP unicast, UDP multicast, and IPC message transport
Beanstalk Simple, fast work queue
Bull 15,464 7 days ago Fast and reliable Redis-based queue for Node
Crossbar 2,050 4 months ago Open source networking platform for distributed and microservice applications. It implements the open Web Application Messaging Protocol (WAMP)
Kafka Publish-subscribe messaging rethought as a distributed commit log
Malamute 322 6 months ago ZeroMQ enterprise messaging broker
Mosca MQTT broker as a module
Mosquitto Open source message broker that implements the MQTT protocol
NATS Open source, high-performance, lightweight cloud messaging system
NSQ A realtime distributed messaging platform
Pulsar Distributed pub-sub messaging system
RabbitMQ Open source Erlang-based message broker that just works
Redpanda 9,485 3 days ago Streaming data platform for developers: Kafka API compatible, 10x faster, no ZooKeeper and no JVM
RocketMQ 21,100 12 days ago A low latency, reliable, scalable, easy to use message oriented middleware born from alibaba massive messaging business
VerneMQ Open source, scalable, Erlang-based MQTT broker

Awesome Microservices / Capabilities / Monitoring & Debugging

Beats Lightweight shippers for Elasticsearch & Logstash
Elastalert 7,991 about 2 months ago Easy & flexible alerting for Elasticsearch
Ganglia A scalable distributed monitoring system for high-performance computing systems such as clusters and grids
Grafana An open source, feature rich metrics dashboard and graph editor for Graphite, InfluxDB & OpenTSDB
Graphite Scalable realtime graphing
IOpipe (c) Application performance monitoring for Amazon Lambda
Jaeger An open source, end-to-end distributed tracing
OpenTelemetry High-quality, ubiquitous, and portable telemetry to enable effective observability
Prometheus An open source service monitoring system and time series database
Riemann Monitors distributed systems
Sensu Monitoring for today's infrastructure
SkyWalking Application performance monitor tool for distributed systems, especially designed for microservices, cloud native and container-based (Docker, K8s, Mesos) architectures
Zabbix Open source enterprise-class monitoring solution
Zipkin Distributed tracing system

Awesome Microservices / Capabilities / Reactivity

Reactor.io A second-generation Reactive library for building non-blocking applications on the JVM based on the Reactive Streams Specification
Reactive Kafka 1,417 5 days ago Reactive Streams API for Apache Kafka
ReactiveX API for asynchronous programming with observable streams. Available for idiomatic Java, Scala, C#, C++, Clojure, JavaScript, Python, Groovy, JRuby, and others
RSocket Application protocol providing Reactive Streams semantics

Awesome Microservices / Capabilities / Resilience

Awesome Chaos Engineering 5,954 9 months ago A curated list of awesome chaos engineering resources
Hystrix 24,081 12 months ago 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
Raft Consensus Consensus algorithm that is designed to be easy to understand. It's equivalent to Paxos in fault-tolerance and performance
Resilience4j 9,702 5 days ago Fault tolerance library designed for Java8 and functional programming
Resilient HTTP A smart HTTP client with super powers like fault tolerance, dynamic server discovery, auto balancing and reactive recovery, designed for distributed systems
Svix Webhooks service that sends webhooks to your users with full retry schedules, exponential backoff, signature verification, and event types

Awesome Microservices / Capabilities / Security

Dex 9,374 11 days ago Opinionated auth/directory service with pluggable connectors. OpenID Connect provider and third-party OAuth 2.0 delegation
JWT JSON Web Tokens are an open, industry standard RFC 7519 method for representing claims securely between two parties
Keycloak 22,499 8 days ago Full-featured and extensible auth service. OpenID Connect provider and third-party OAuth 2.0 delegation
Light OAuth2 313 9 months ago A fast, lightweight and cloud native OAuth 2.0 authorization microservices based on light-java
OAuth Provides specific authorization flows for web applications, desktop applications, mobile phones, and living room devices. Many implementations
OpenID Connect Libraries, products, and tools implementing current OpenID specifications and related specs
Open Ziti Zero trust security and overlay networking as pure open source software
ORY Open source identity infrastructure and services
SCIM System for Cross-domain Identity Management
Vault Secures, stores, and tightly controls access to tokens, passwords, certificates, API keys, and other secrets in modern computing

Awesome Microservices / Capabilities / Serialization

Avro Apache data serialization system providing rich data structures in a compact, fast, binary data format
Bond 2,610 3 days ago Cross-platform framework for working with schematized data, broadly used at Microsoft in high scale services
BooPickle 367 about 2 months ago Binary serialization library for efficient network communication. For Scala and Scala.js
Cap’n Proto Insanely fast data interchange format and capability-based RPC system
CBOR Implementations of the CBOR standard (RFC 7049) in many languages
Cereal C++11 library for serialization
Cheshire 1,486 about 2 months ago Clojure JSON and JSON SMILE encoding/decoding
Etch Cross-platform, language and transport-independent framework for building and consuming network services
Fastjson 25,723 3 months ago Fast JSON Processor
Ffjson 2,960 about 1 year ago Faster JSON serialization for Go
FST 1,583 over 1 year ago Fast java serialization drop in-replacement
Jackson 9,057 3 months ago A multi-purpose Java library for processing JSON data format
Jackson Afterburner 91 almost 5 years ago Jackson module that uses bytecode generation to further speed up data binding (+30-40% throughput for serialization, deserialization)
Kryo 6,181 5 days ago Java serialization and cloning: fast, efficient, automatic
MessagePack Efficient binary serialization format
Protostuff 2,043 11 months ago A serialization library with built-in support for forward-backward compatibility (schema evolution) and validation
SBinary 75 almost 9 years ago Library for describing binary formats for Scala types
Thrift The Apache Thrift software framework, for scalable cross-language services development

Awesome Microservices / Capabilities / Storage

Alluxio 6,816 23 days ago Virtual distributed storage system
Apache Cassandra Column-oriented and providing high availability with no single point of failure
Aerospike (c) High performance NoSQL database delivering speed at scale
ArangoDB A distributed free and open source database with a flexible data model for documents, graphs, and key-values
AtlasDB 53 8 days ago Transactional layer on top of a key value store
Citus 10,405 12 days ago Distributed PostgreSQL as an extension
ClickHouse Column-oriented database management system that allows generating analytical data reports in real time
CockroachDB (c) A cloud-native SQL database modelled after Google Spanner
Couchbase A distributed database engineered for performance, scalability, and simplified administration
Crate (c) Scalable SQL database with the NoSQL goodies
Datomic Fully transactional, cloud-ready, distributed database
Druid Fast column-oriented distributed data store
Elasticsearch Open source distributed, scalable, and highly available search server
Geode Open source, distributed, in-memory database for scale-out applications
Infinispan Highly concurrent key/value datastore used for caching
InfluxDB 28,713 2 days ago Scalable datastore for metrics, events, and real-time analytics
OpenTSDB Scalable and distributed time series database written on top of Apache HBase
Pilosa 2,529 8 months ago Open source, distributed bitmap index that dramatically accelerates queries across multiple, massive data sets
RethinkDB Open source, scalable database that makes building realtime apps easier
Secure Scuttlebutt 61 almost 3 years ago P2P database of message-feeds
TiKV Distributed transactional key-value database
Trino Fast distributed SQL query engine for big data analytics that helps you explore your data universe

Awesome Microservices / Capabilities / Testing

Goreplay 18,593 2 months ago A tool for capturing and replaying live HTTP traffic into a test environment
Mitmproxy An interactive console program that allows traffic flows to be intercepted, inspected, modified and replayed
Mountebank Cross-platform, multi-protocol test doubles over the wire
Pact Contract testing framework for HTTP APIs and non-HTTP asynchronous messaging systems
RestQA 85 22 days ago A tool to manage microservices mocking, unit and performance testing locally with best in class developer experience
Spring Cloud Contract TDD to the level of software architecture
VCR 5,827 about 1 month ago 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 58 about 1 month ago Combined HTTP/HTTPS service stub and transparent proxy solution
WireMock 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
Hoverfly 2,349 about 1 month ago Lightweight service virtualization/API simulation tool for developers and testers

Awesome Microservices / Continuous Integration & Delivery

Awesome CI/CD DevOps 1,858 6 months ago A curated list of awesome tools for continuous integration, continuous delivery and DevOps

Awesome Microservices / Web API Modeling & Documentation / GraphQL

GraphQL Query language designed to build client applications by providing an intuitive and flexible syntax and system for describing their data requirements and interactions

Awesome Microservices / Web API Modeling & Documentation / JSON

JSON:API A specification for how a client should request that resources be fetched or modified, and how a server should respond to those requests

Awesome Microservices / Web API Modeling & Documentation / REST

API Blueprint 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
OpenAPI The OpenAPI Specification (OAS) provides a consistent means to carry information through each stage of the API lifecycle
RAML RESTful API Modeling Language, a simple and succinct way of describing practically-RESTful APIs
ReDoc 23,333 16 days ago OpenAPI/Swagger-generated API Documentation
Slate 36,025 4 months ago Beautiful static documentation for your API
Spring REST Docs Document RESTful services by combining hand-written documentation with auto-generated snippets produced with Spring MVC Test
Swagger A simple yet powerful representation of your RESTful API

Awesome Microservices / Standards / Recommendations / World Wide Web

W3C.REC-Webarch Architecture of the World Wide Web, Volume One
RFC3986 Uniform Resource Identifier (URI): Generic Syntax
RFC6570 URI Template
RFC7320 URI Design and Ownership

Awesome Microservices / Standards / Recommendations / Self-sovereignty & Decentralisation

DID W3C specification of Decentralized identifiers (DIDs): a new type of identifier that enables verifiable, decentralized digital identity
DIDComm 165 5 months ago Private communication methodology built atop the decentralized design of DIDs
DIDComm Protocols Registry of protocols built on DIDComm, for high-trust, self-sovereign interactions over any transport
IDSA The International Data Spaces Association (IDSA) is on a mission to create the future of the global, digital economy with International Data Spaces (IDS), a secure, sovereign system of data sharing in which all participants can realize the full value of their data

Awesome Microservices / Standards / Recommendations / HTTP/1.1

RFC7230 Message Syntax and Routing
RFC7231 Semantics and Content
RFC7232 Conditional Requests
RFC7233 Range Requests
RFC7234 Caching
RFC7235 Authentication
RFC7807 Problem Details for HTTP APIs

Awesome Microservices / Standards / Recommendations / HTTP/2

RFC7540 Hypertext Transfer Protocol Version 2

Awesome Microservices / Standards / Recommendations / QUIC

QUIC-WG IETF Working Group that is chartered to deliver the next transport protocol for the Internet
QUIC-Transport A UDP-based multiplexed and secure transport

Awesome Microservices / Standards / Recommendations / RPC

JSON-RPC 2.0 A stateless, light-weight remote procedure call (RPC) protocol
Open RPC The OpenRPC Specification defines a standard, programming language-agnostic interface description for JSON-RPC 2.0 APIs

Awesome Microservices / Standards / Recommendations / Messaging

AMQP Advanced Message Queuing Protocol
MQTT MQ Telemetry Transport
STOMP Simple Text Oriented Messaging Protocol

Awesome Microservices / Standards / Recommendations / Security

GNAP Grant Negotiation and Authorization Protocol defines a mechanism for delegating authorization to a piece of software, and conveying that delegation to the software. This delegation can include access to a set of APIs as well as information passed directly to the software
OIDCONN 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
PASETO Paseto is everything you love about JOSE (JWT, JWE, JWS) without any of the many design deficits that plague the JOSE standards
RFC5246 The Transport Layer Security (TLS) Protocol Version 1.2
RFC6066 TLS Extensions
RFC6347 Datagram Transport Layer Security Version 1.2
RFC6749 The OAuth 2.0 authorization framework
RFC6962 Certificate transparency
RFC7515 JSON Web Signature (JWS) represents content secured with digital signatures or Message Authentication Codes (MACs) using JSON-based data structures
RFC7519 JSON Web Token (JWT) is a compact, URL-safe means of representing claims to be transferred between two parties
RFC7642 SCIM: Definitions, overview, concepts, and requirements
RFC7643 SCIM: Core Schema, provides a platform-neutral schema and extension model for representing users and groups
RFC7644 SCIM: Protocol, an application-level, REST protocol for provisioning and managing identity data on the web

Awesome Microservices / Standards / Recommendations / Service Discovery

DNS-SD Mechanism for clients to discover a list of named instances of a service, using standard DNS queries
RFC2782 A DNS RR for specifying the location of services (DNS SRV)

Awesome Microservices / Standards / Recommendations / Data Formats

RFC4627 JavaScript Object Notation (JSON)
RFC7049 Concise Binary Object Representation (CBOR)
BSON Binary JSON (BSON)
JSON-LD JSON for Linking Data
SBE 257 3 months ago Simple Binary Encoding (SBE)
MSGPACK 6,974 about 2 months ago MessagePack Specification

Awesome Microservices / Standards / Recommendations / Vocabularies

JSON Schema Vocabulary that allows you to annotate and validate JSON documents
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

Awesome Microservices / Standards / Recommendations / Unicode

UNIV8 The Unicode Consortium. The Unicode Standard, Version 8.0.0, (Mountain View, CA: The Unicode Consortium, 2015. ISBN 978-1-936213-10-8)
RFC3629 UTF-8, a transformation format of ISO 10646

Awesome Microservices / Organization Design / Team Dynamics

How Do Committees Invent? Melvin E. Conway, Datamation magazine 1968. The original article defining Conway's Law
Service per Team Each team is responsible for one or more business functions (e.g. business capabilities). A team owns a code base consisting of one or more modules. Its code base is sized so as to not exceed the cognitive capacity of team. The team deploys its code as one or more services. A team should have exactly one service unless there is a proven need to have multiple services
Start with Team Cognitive Load - Team Topologies DOES19 London. The "monoliths vs microservices" debate often focuses on technological aspects, ignoring strategy and team dynamics. Instead of technology, smart-thinking organizations are beginning with team cognitive load as the guiding principle for modern software. In this talk, we explain how and why, illustrated by real case studies

Awesome Microservices / Enterprise & Verticals

Commercetools Headless commerce platform
Equinox Infosys Equinox is a human-centric commerce and marketing platform that supports rich, hyper-personalized experiences across any channel and touchpoint
Flamingo Framework to build flexible and modern e-commerce applications
Medusa Headless open source commerce platform

Awesome Microservices / Theory / Articles & Papers

Autonomy, Hyperconnectivity, and Residual Causality Philosophical introduction to the design of adaptive hyperliminal systems through complexity science theories
Awesome Scalability 58,423 about 1 month ago An updated and organized reading list for illustrating the patterns of scalable, reliable, and performant large-scale systems. Concepts are explained in the articles of prominent engineers and credible references. Case studies are taken from battle-tested systems that serve millions to billions of users
A Sidecar for Your Service Mesh A short service mesh introduction
AKF Scale Cube Model depicting the dimensions to scale a service
Building Microservices? Here is What You Should Know A practical overview, based on real-world experience, of what one would need to know in order to build microservices
CALM Consistency as logical monotonicity
Canary Release 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 States that it is impossible for a distributed computer system to simultaneously provide all three of the following guarantees: Consistency, Availability and Partition tolerance
Formal Foundations of Serverless Computing The serverless computing abstraction exposes several low-level operational details that make it hard for programmers to write and reason about their code. This paper sheds light on this problem by presenting λ, an operational semantics of the essence of serverless computing
Java Microservices: A Practical Guide You can use this guide to understand what Java microservices are, how you architect and build them. Also: A look at Java microservice libraries & common questions
Microservice Architecture Particular way of designing software applications as suites of independently deployable services
Microservices – Please, don’t Critical advice about some problems regarding a microservices approach
Microservices RefCard Getting started with microservices
Microservices Trade-Offs Guide to ponder costs and benefits of the mircoservices architectural style
Reactive Manifesto Reactive systems definition
Reactive Streams Initiative to provide a standard for asynchronous stream processing with non-blocking back pressure
ROCAS Resource Oriented Computing for Adaptive Systems
SECO Understanding software ecosystems: a strategic modeling approach
Testing Strategies in a Microservice Architecture Approaches for managing the additional testing complexity of multiple independently deployable components
Your Server as a Function Describes three abstractions which combine to present a powerful programming model for building safe, modular, and efficient server software: Composable futures, services and filters

Awesome Microservices / Theory / Sites & Organizations

Cloud Native Computing Foundation The Cloud Native Computing Foundation builds sustainable ecosystems and fosters a community around a constellation of high-quality projects that orchestrate containers as part of a microservices architecture
CNCF Cloud Native Interactive Landscape Interactive landscape of cloud native technologies
Microservices Resource Guide Martin Fowler's choice of articles, videos, books, and podcasts that can teach you more about the microservices architectural style
Microservice Patterns Microservice architecture patterns and best practices
Microservice Antipatterns and Pitfalls Microservice mostly known antipatterns and pitfalls

Backlinks from these awesome lists: