Jump to content

Twelve-Factor App methodology

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by 46.53.178.47 (talk) at 11:36, 5 January 2018 (Criticism and adaptation). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

The Twelve-Factor App methodology is a methodology for building software as a service applications. These best practices are designed to enable applications to be built with portability and resilience when deployed to the web.[1]

History

The methodology was drafted by developers at Heroku and was first presented by Adam Wiggins circa 2011.[1]

The Twelve Factors

The Twelve Factors
# Factor Description
I Codebase There should by exactly one codebase for a deployed service with the codebase being used for many deployments.
II Dependencies All dependencies should be declared, with no implicit reliance on system tools or libraries.
III Config Configuration that varies between deployments should be stored in the environment.
IV Backing services All backing services are treated as attached resources and attached and detached by the execution environment.
V Build, release, run The delivery pipeline should strictly consist of build, release, run.
VI Processes Applications should be deployed as one or more stateless processes with persisted data data stored on a backing service.
VII Port binding Self contained services should make themselves available to other services by specified ports.
VIII Concurrency Concurrency is advocated by scaling individual processes.
IX Disposability Fast startup and shutdown are advocated for a more robust and resilient system.
X Dev/Prod parity All environments should be as similar as possible.
XI Logs Applications should produce logs as event streams and leave the execution environment to aggregate.
XII Admin Processes Any needed admin tasks should be kept in source control and packaged with the application.

[1][2]

Criticism and adaptation

As of 2017 a number of more recent references to the Twelve-Factor app may comment on how it is a creditworthy effort remaining generally applicable but have suggested they feel some principles were specific to Heroku Platform as a service.[3]. The twelve factors are however cited as the baseline methodology from which it has been felt necessary to adapt or extend. [3][4]

References

  1. ^ a b c Hofmann,, Michael; Schnabel, Erin; Stanley, Katherine (13 March 2017). Microservices Best Practices for Java. IBM Redbooks. p. 2—3. ISBN 9780738442273.{{cite book}}: CS1 maint: extra punctuation (link)
  2. ^ Wiggins, Adam. "The Twelve-Factor App". Archived from the original on 13 June 2017. Retrieved 21 December 2017.
  3. ^ a b Horowitz, Ben (28 July 2016). "MRA, Part 5: Adapting the Twelve‑Factor App for Microservices". NGINX. Archived from the original on 22 December 2017. Retrieved 22 December 2017. {{cite web}}: Unknown parameter |dead-url= ignored (|url-status= suggested) (help)
  4. ^ "Beyond the Twelve-Factor App - Exploring the DNA of Highly Scalable, Resilient Cloud Applications". O'Reilly. Retrieved 22 December 2017.