Print

 

Microservices is the prevailing architecture style of choice for building software products from reusable APIs. The organizational and technical approaches it champions are a wiser version of Service Oriented Architecture (SOA) of years past that also incorporates the Representational State Transfer (REST) architecture style — the bar by which industry uses to assess the goodness of API design.

The subject of a future blog post is The Failings of SOA, the Microservices Architecture Style as Successor will tell an interesting story and provides the context for how we build software from reusable components today and why.

Another related and forthcoming blog post is REST Architecture Style Adaptations for Practical API Design, a story advocating for “impure” adoption of REST out of necessity.

Just as with SOA, the microservices architecture style is broad in scope, recommending many organizational, architectural, and developmental best practices. This makes it a bit challenging to understand and even harder to achieve as an enterprise organizational competancy. The purpose of the Microservices Scorecard is to distill this architecture style down to its essence as a means for introducing it to new adopters, and to provide a framework for assessing the degree to which an enterprise and its products adhere to the style.

The scorecards is based on the foundational work of James Lewis and Martin Fowler, Microservices, A Definition of this New Architectural Term*.

Scorecard Philosophy

The scorecards enables a ballpark estimate of architecture adherence using easy to understand criteria that is organized and structured to facilitate gap analysis and the elaboration of remediation plans. The scorecard is purposefully straightforward to use — it avoids being overly prescriptive about implementation, nor does it attempt to imply there is a correct sequence for which to mature an architecture, nor does it say which criteria of the architecture are most important to achieve. Past experience with SOA provides pretty good indication that the goals of organizations adopting an architecture style vary considerably and it naturally follows that it is reasonable, in fact recommended, to customize an architecture based on unique organizational needs.

Key Terminology

Without being exhaustive, or exhausting to the reader, let us baseline a few terms. Terms are defined specifically for this scorecard but some parts of their descriptions you will recognize from more general and broad definitions found in industry for REST, software reuse, etc.

Scorecard

The scorecard organizes criteria around practice areas akin to past SOA maturity models. For those unfamiliar with microservices architecture, practice areas provide a useful high level understanding of its scope. Practice areas are purposefully ordered with those at the top being more intrinsic to the definition of microservices than those at the bottom, which tend to be better understood as new complimentary practices of the day. Each practice area includes criteria that further characterize the properties of a microservices architecture. An organization can score the degree to which it meets each criterion:

 

 

Granularity and Reuse

A microservices architecture decomposes software into reusable APIs whose granularity facilitates building a variety of experiences through the mixing-and-matching of alternative API combinations.

Independence

Inline with the “design for change” principle, a microservices architecture decomposes software into independent modules that enable graceful (less expensive) software evolution.

Service Architecture

A microservices architecture carefully decomposes software functionality into APIs whose implementation is hidden from consumers and follows a layered architecture that further separates and encapsulates software according to service-oriented best practices.

Alignment

Much as with SOA, a microservices architecture identifies and defines a set of services to build that are strategic to the enterprise. There is a clear linkage of services to their customer value proposition and to the value of building once and reusing.

Ownership

Much as with SOA, a microservices architecture prescribes clear and consistent ownership of services.

Automation

A microservice architecture advocates for significant use of automation throughout development and software operation.

Governance

A microservice architecture advocates for balanced governance where a central authority and individual service providers share the responsibility for conceiving of and doing the right things for their customers and their enterprise.