Release It! Second Edition
Design and Deploy Production-Ready Software
by: Michael Nygard
Published | 2018-01-05 |
---|---|
Internal code | mnee2 |
Print status | In Print |
Pages | 376 |
User level | Advanced |
Keywords | devops, scalable, reliable, fault-tolerant, microservices, patterns, antipatterns, production, deploy, security |
Related titles |
|
ISBN | 9781680502398 |
Other ISBN |
Channel epub: 9781680504521 Channel PDF: 9781680504538 Kindle: 9781680504545 Safari: 9781680504552 Kindle: 9781680504545 |
BISACs | COM051230 COMPUTERS / Software Development & Engineering / GeneralCOM061000 COMPUTERS / Client-Server ComputingCOM061000 COMPUTERS / Client-Server Computing |
Highlight
A single dramatic software failure can cost a company millions of dollars—but can be avoided with simple changes to design and architecture. This new edition of the best-selling industry standard shows you how to create systems that run longer, with fewer failures, and recover better when bad things happen. New coverage includes DevOps, microservices, and cloud-native architecture. Stability antipatterns have grown to include systemic problems in large-scale systems. This is a must-have pragmatic guide to engineering for production systems.
Description
If you’re a software developer, and you don’t want to get alerts every night for the rest of your life, help is here. With a combination of case studies about huge losses—lost revenue, lost reputation, lost time, lost opportunity—and practical, down-to-earth advice that was all gained through painful experience, this book helps you avoid the pitfalls that cost companies millions of dollars in downtime and reputation. Eighty percent of project life-cycle cost is in production, yet few books address this topic.
This updated edition deals with the production of today’s systems—larger, more complex, and heavily virtualized—and includes information on chaos engineering, the discipline of applying randomness and deliberate stress to reveal systematic problems. Build systems that survive the real world, avoid downtime, implement zero-downtime upgrades and continuous delivery, and make cloud-native applications resilient. Examine ways to architect, design, and build software—particularly distributed systems—that stands up to the typhoon winds of a flash mob, a Slashdotting, or a link on Reddit. Take a hard look at software that failed the test and find ways to make sure your software survives.
To skip the pain and get the experience…get this book.
Contents and Extracts
- Introduction <b>excerpt</b>
- Create Stability
- Case Study: The Exception That Grounded an Airline
- The Change Window
- The Outage
- Consequences
- Postmortem
- Hunting for Clues
- The Smoking Gun
- An Ounce of Prevention?
- Stabilize Your System
- Defining Stability
- Extending Your Life Span
- Failure Modes
- Stopping Crack Propagation
- Chain of Failure
- Wrapping Up
- Stability Antipatterns <b>excerpt</b>
- Integration Points
- Chain Reactions
- Cascading Failures
- Users
- Blocked Threads
- Self-Denial Attacks
- Scaling Effects
- Unbalanced Capacities
- Dogpile
- Force Multiplier
- Slow Responses
- Unbounded Result Sets
- Wrapping Up
- Stability Patterns
- Timeouts
- Circuit Breaker
- Bulkheads
- Steady State
- Fail Fast
- Let It Crash
- Handshaking
- Test Harnesses
- Decoupling Middleware
- Shed Load
- Create Back Pressure
- Governor
- Wrapping Up
- Case Study: The Exception That Grounded an Airline
- Design for Production
- Case Study: Phenomenal Cosmic Powers, Itty-Bitty Living Space
- Baby’s First Christmas
- Taking the Pulse
- Thanksgiving Day
- Black Friday
- Vital Signs
- Diagnostic Tests
- Call In a Specialist
- Compare Treatment Options
- Does the Condition Respond to Treatment?
- Winding Down
- Foundations
- Networking in the Data Center and the Cloud
- Physical Hosts, Virtual Machines, and Containers <b>excerpt</b>
- Wrapping Up
- Processes on Machines
- Code
- Configuration
- Transparency
- Wrapping Up
- Interconnect
- Solutions at Different Scales
- DNS
- Load Balancing
- Demand Control
- Network Routing
- Discovering Services
- Migratory Virtual IP Addresses
- Wrapping Up
- Control Plane
- How Much Is Right for You?
- Mechanical Advantage
- Platform and Ecosystem
- Development Is Production
- System-Wide Transparency
- Configuration Services
- Provisioning and Deployment Services
- Command and Control
- The Platform Players
- The Shopping List
- Wrapping Up
- Security
- The OWASP Top 10
- The Principle of Least Privilege <b>excerpt</b>
- Configured Passwords
- Security as an Ongoing Process
- Wrapping Up
- Case Study: Phenomenal Cosmic Powers, Itty-Bitty Living Space
- Deliver Your System
- Case Study: Waiting for Godot
- Design for Deployment
- So Many Machines
- The Fallacy of Planned Downtime
- Automated Deployments
- Continuous Deployment
- Phases of Deployment
- Deploy Like the Pros
- Wrapping Up
- Handling Versions
- Help Others Handle Your Versions
- Handle Others’ Versions
- Wrapping Up
- Solve Systemic Problems
- Case Study: Trampled by Your Own Customers
- Countdown and Launch
- Aiming for Quality Assurance
- Load Testing
- Murder by the Masses
- The Testing Gap
- Aftermath
- Adaptation
- Convex Returns
- Process and Organization
- System Architecture
- Information Architecture
- Wrapping Up
- Chaos Engineering
- Breaking Things to Make Them Better
- Antecedents of Chaos Engineering
- The Simian Army
- Adopting Your Own Monkey
- Disaster Simulations
- Wrapping Up
- Case Study: Trampled by Your Own Customers