Deploy vs Release: Aka Release Toggles are your Friend

Deploy vs Release: Aka Release Toggles are your Friend

Not to be pedantic, but as a long-time Product guy, working with dev teams large & small, young & mature, I have often found the terms ‘Deploy’ and ‘Release’ ambiguous and routinely perverted. More to the point: the underlying software lifecycle management practices they refer to are often conflated, robbing us of a key ability to better serve our customers and react to changing market needs.

I was spurred to write this piece by this article from Launch Darkly on 4 Risk Mitigation Strategies for Software Releases which was cross-posted to LinkedIn. Before getting into their four strategies, the author directs us to ‘Decouple deploy from release: You can ship a software change to a production location without exposing it to production traffic.’

Yes! But risk mitigation is merely one benefit of distinguishing & optimizing these two very different things.

I should note a couple of things here: 1) This is not a dev topic – at least not solely a dev topic. Product should provide guidance & leadership here as creating customer value is what we’re accountable for, and having that value locked away from those customers becomes our problem. 2) I won’t cover topics such as CI/CD, DevOps, or even NoOps . If you can do any or all that, wonderful. Too many companies cannot. But even in orgs w/the most primitive practices, as Product Leaders, there are things we can and should embrace and facilitate.

Delivering quality software takes time, sometimes way longer than we think it should or want it to. I’ve worked in companies that suffered protracted dev & testing cycles – as long as four weeks of regression – often due to legacy, monolithic, and fragile code bases. You never quite knew what you might break as a result of changing even the seemingly slightest thing. I get that and it’s a tech debt discussion for another day. The business challenge is that we couldn’t release business value any faster than this pace.

I know what you’re thinking: Why not just release monthly, or release whenever your code makes it through the gauntlet? Here are just three reasons why:

1) You may not want all features or new capabilities to go to all customers or all users. Think about pre-release programs, A/B testing, special offers, or even fixes to esoteric problems that affect only some customers.

2) Releasing value to customers requires thoughtful, coordinated prep, well beyond dev & ops. This is a team sport, and Product must enable multiple players for effective GTM readiness: Product Marketing, Sales, Support, Success, Services, and, if there are pricing changes, Finance. Customers may also need to take steps to get ready for new functionality (I still have scars from several well-intended SSO user migrations). We must ensure ‘No surprises’ when customers get new things! This planning can take several weeks, ideally begins long before the code is ready, and helps ensure we deliver maximum market impact and minimum customer disruption.

3) We may need to do several incremental deployments, over weeks or longer to get all the pieces of new infrastructure in place. Dev often needs to build ‘scaffolding’ to frame dormant code before all code dependencies are in place and ready for activation. Customers must be kept away from these active construction zones & hazards.

I fell in love with release toggles back in 2017. They were already commonplace for cloud-native SaaS providers but were still a novelty for many enterprise and legacy software providers. They provided us with a new degree of freedom and allowed Product to ‘throw the switch(es)’ on already-deployed code when we wanted to release new capabilities.

Here’s a handy chart I developed that helped us distinguish and best utilize both practices.

Table - Yes, they are different things

There is at least one notable exception to the above: Fixes to Critical (‘Sev-0’) defects should be pushed to affected customers with a minimum of delay, so in this case, a rapid fix & deploy is necessary for an emergency release and must have minimum separation.

Your engineers may be tempted to build your own release toggles. Don’t do it! It’s likely not your core competency and will become yet another thing to enhance and maintain. Today, there are several commercial products available including Launch Darkly , Optimizely , and Harness , to name a few. Caveat: these products can get expensive as you expand their use. Fortunately, there are also several free and open source options available .

Finally, for a deeper dive, see this excellent article by Martin Fowler Feature Toggles (aka Feature Flags )

So, Product Peeps: if you’re not using feature flags today, what are you waiting for?

If you are already in the know, what other benefits and caveats have you found from separating Deploying and Releasing?


James Heggs

CTO and Co-Founder @ Tech Returners, Tech Director @ Counter, Co-organiser DevOps Manchester

2 个月

Love this and the importance of language within the environment I made similar remarks a few years ago around DRL cycles DRL Cycle https://www.dhirubhai.net/pulse/drl-cycle-james-heggs?utm_source=share&utm_medium=member_android&utm_campaign=share_via

Martin Fowler

Author of Refactoring, hosts martinfowler.com, Thoughtworker

2 个月

I'm glad you liked the article "Feature Toggles (aka Feature Flags)", but I should point out the author is Pete Hodgson. I'm just the lucky publisher.

要查看或添加评论,请登录

社区洞察

其他会员也浏览了