The Twelve-Factor App
"A methodology for building software-as-a-service applications"
http://12factor.net/
Who?
The Heroku Team
"Our motivation is to raise awareness of some systemic problems we’ve seen in modern application development, to provide a shared vocabulary for discussing those problems, and to offer a set of broad conceptual solutions to those problems with accompanying terminology."
Why?
The 12 Factors:
1.
Codebase
One codebase, tracked in revision control, many deploys
2.
Dependencies
Explicitly declare and isolate dependencies.
Gemfile
Ruby Examples
bundle exec
3.
Config
Store config in the environment
If your codebase was made open source, would you expose credentials?
4.
Backing Services
Treat backing services as attached resources
External Services
Your code shouldn't know the difference if you changed out a local redis instance with one served by AWS through Elisticache.
5.
Build, Release, Run
Strictly separate build and run stages.
The build stage is managed by devs and it does all the heavy lifting. The run stage should be simple and bullet-proof so if an app has to restart, it shouldn't need any human intervention.
6.
Processes
Execute the app as one or more stateless processes
Data should be stored in a database or persistent key-value store like redis so if one server goes down in the middle of a users session, another server can handle the traffic and the app is none the wiser.
7.
Port Binding
Export services via port binding
Example: You have an API that serves external customers (untrusted) as well as your web app (trusted). You might set up a separate url that your web app uses that bypasses firewall and authentication so it's a bit faster.
8.
Concurrency
Scale out via the process model
Have lots of little processes handling individual tasks.
Ex: 1 process handles http traffic,
1 process handles websockets,
1 process handles sending welcome emails, etc...
"In the 12 factor app, processes are a first-class citizen."
9.
Disposability
Maximize robustness with fast startup and graceful shutdown.
If your app crashes, it should be able to start back up quickly and cleanly.
Beyond loading code, your app should have everything it needs waiting in high speed databases or caches so it can start up snappily and be ready to serve requests.
10.
Dev/Prod Parity
Keep development, staging and production as similar as possible.
It's more desirable to be able to develop and deploy changes quickly. In order to facilitate this, it's best to make a developer's local environment as close to production as possible.
I.E. - using the same backing services, the same configuration management techniques, the same versions of software libraries, etc...
11.
Logs
Treat logs as event streams.
In the ideal situation, the logs should be captured as a stream of events and pushed into a real time consolidated system for long-term archival and data-mining.
At the very least, you should be capturing errors and sending them to an error reporting service like New Relic or Air Brake.
12.
Admin Processes
Run admin/management tasks as one-off processes.
One-off tasks like cleaning up data, running analytics for a presentation, turning on and off features for A/B testing should be run in an identical environment as production.
Don't run updates directly against a database or from a local terminal window.
Thanks!
Resources:
http://12factor.net/
http://www.clearlytech.com/2014/01/04/12-factor-apps-plain-english/
The 12 Factor App
By mattspell
The 12 Factor App
- 1,862