Team Guide to Software Operability
Team Guide to Software Operability
$18.00
Minimum price
$24.00
Suggested price
Team Guide to Software Operability

This book is 27% complete

Last updated on 2018-05-29

About the Book

Team Guide to Software Operability is the first guidebook in the new collection from Skelton Thatcher Publications.

Learn how a focus on software operability helps to increase system reliability, reduce problems in Production, and reduce total cost of ownership (TCO).

The ‘Team Guide’ collection is designed to help teams building and running software systems to be as effective as possible.

Guides are curated by experienced practitioners and emphasise the need for collaboration and learning, with the team at the centre.

About the Authors

Matthew Skelton
Matthew Skelton

Matthew Skelton has been building, deploying, and operating commercial software systems since 1998. Head of Consulting at Conflux (confluxdigital.net), he specialises in Continuous Delivery, operability and organisation design for software in manufacturing, ecommerce, and online services, including cloud, IoT, and embedded software.

Matthew curates the well-known DevOps team topologies patterns at devopstopologies.com and is co-author of the books Continuous Delivery with Windows and .NET (O’Reilly, 2016) and Team Guide to Software Operability (Skelton Thatcher Publications, 2016). He is also co-founder at Skelton Thatcher Publications (skeltonthatcher.com), a specialist publisher of techniques for software teams.

confluxdigital.net / @matthewpskelton

Rob Thatcher
Rob Thatcher

Rob Thatcher has worked on technology deployment, management and support projects in the financial services industry for over 15 years, with technologies including Solaris, Linux, Microsoft, Cisco and Juniper networking.

Prior to that he spent time working in a range of IT roles from task scheduling to teaching and mentoring IT skills in the workplace.

He has built and led successful matrix teams, combining IT staff across multiple disciplines, for managing electronic trading platforms, technical infrastructure, remote offices, VPN services, virtual machines, and storage platforms. He has co-built four trading floors in the City of London along with associated data-centre and Direct Market Access components.

About the Contributors

Manuel Pais
Manuel Pais

Manuel Pais is an independent DevOps and Delivery Consultant, focused on teams and flow.

With a diverse experience including development, build management, testing and QA, Manuel has helped large organizations in finance, legal, and manufacturing adopt test automation and continuous delivery, as well as understand DevOps from both technical and human perspectives.

Manuel is co-author of the Team Guide to Software Releasability book and lead editor for the remaining books in the Team Guide series.

Table of Contents

  • The Team Guide series
  • Foreword
  • Introduction
    • What is software operability and why should we care?
    • Where can operability techniques be used?
    • How to use this book
    • What is covered in this book
    • Feedback and suggestions
  • 1. What does good operability look like?
  • 2. Core practices for good software operability
    • 2.1 Logging and metrics are the first features to implement
    • 2.2 Use a well-defined, meaningful event identifiers
    • 2.3 Include operational hooks as first-class features
    • 2.4 ‘DONE’ means working correctly in Production
    • 2.5 Treat Operations as a high-skill activity
    • 2.6 The software development team writes a draft Run Book
    • 2.7 Avoid a separate ‘Production-ization’ or ‘Hardening’ phase
    • 2.8 Avoid Production-specific tools
    • 2.9 Talk about ‘operational features’, not ‘non-functional requirements’
    • 2.10 Developers and Product Owners should be on-call
    • 2.11 Make operational problems visible
    • 2.12 Test for operability in a deployment pipeline
    • 2.13 Summary
  • 3. Use Run Book collaboration to increase operability and prevent operational issues
    • 3.1 Operational aspects are very similar across many software systems
    • 3.2 Use a Run Book template as a common baseline for operational aspects
    • 3.3 Use a Run Book Dialogue Sheet to facilitate discovery and avoid ‘documentation fallacy’
    • 3.4 Assess operability on a regular basis: every sprint, iteration, or week
    • 3.5 Summary
  • 4. Use modern log aggregation and metrics for deep operational insights
    • 4.1 Use logging to help design and understand distributed systems
    • 4.2 Collect and aggregate logs and metrics centrally using standard tools & software
    • 4.3 Focus on collaboration, design decisions, and team experience
    • 4.4 Identify 2 or 3 key application metrics and test these early on
    • 4.5 Run log aggregation and metrics locally on development workstations
    • 4.6 Hide sensitive information at the point of logging
    • 4.7 Use Structured Logging for greater meaning
    • 4.8 Use Event IDs for visibility of application behaviour
    • 4.9 Collaborate on Event IDs to enhance operability
    • 4.10 Test your logging and metrics
    • 4.11 Trace operations across system boundaries with correlation IDs
    • 4.12 Adapt your logging and metrics techniques to the technology characteristics
    • 4.13 Summary
  • 5. Use Deployment Verification Tests and Endpoint Healthchecks for rapid feedback on environments
  • 6. Run operational checks within a deployment pipeline to gain rapid feedback and increased collaboration
  • 7. Use information radiators and dashboards to drive effective behaviour and good psychological responses
  • 8. Use operability as a differentiating aspect of your software
  • 9. Appendix
    • 9.1 Adapt your logging techniques to the technology characteristics
    • 9.2 Logging and metrics for applications running on x86-based machines
    • 9.3 Logging and metrics for containers and containerized applications
    • 9.4 Logging and metrics for Serverless / Function-as-a-Service (FaaS) and Platform-as-a-Service (PaaS)
    • 9.5 Logging and metrics for IoT / connected devices and embedded systems
    • 9.6 Logging and metrics for mobile apps
  • Terminology
  • References and further reading
    • Introduction
    • Chapter 1 - What does good operability look like?
    • Chapter 2 - Core Operability Practices
    • Chapter 3 - Use Run Book collaboration to increase operability and prevent operational issues
    • Chapter 4 - Use modern log aggregation for deep operational and insights
    • Chapter 5 - Use Deployment Verification Tests and Endpoint Healthchecks for rapid feedback on environments
    • Chapter 6 - Run operational checks within a deployment pipeline to gain rapid feedback and increased collaboration
    • Chapter 7 - Use information radiators and dashboards to drive effective behaviour and good psychological responses
    • Chapter 8 - Use operability as a differentiating aspect of your software
    • Appendix
  • Run Book template
    • Service or system overview
    • System characteristics
    • Required resources
    • Security and access control
    • System configuration
    • System backup and restore
    • Monitoring and alerting
    • Operational tasks
    • Maintenance tasks
    • Failover and Recovery procedures
  • About the authors
    • Matthew Skelton
    • Rob Thatcher
    • Why we wrote this book
  • Notes

About the Publisher

This book is published on Leanpub by Skelton Thatcher Publications

Developing and running modern software systems requires teams of motivated and well-trained people; however, most IT books are written for the individual technologist. The Team Guide series from Skelton Thatcher Publications takes a team-first approach to software systems with the aim of empowering whole teams to build and operate software systems more effectively.

The Leanpub 45-day 100% Happiness Guarantee

Within 45 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.

See full terms...

Write and Publish on Leanpub

Authors, publishers and universities use Leanpub to publish amazing in-progress and completed books and courses, just like this one. You can use Leanpub to write, publish and sell your book or course as well! Leanpub is a powerful platform for serious authors, combining a simple, elegant writing and publishing workflow with a store focused on selling in-progress ebooks. Leanpub is a magical typewriter for authors: just write in plain text, and to publish your ebook, just click a button. It really is that easy.

Learn more about writing on Leanpub