DevOps Zone is brought to you in partnership with:

Mark is a graph advocate and field engineer for Neo Technology, the company behind the Neo4j graph database. As a field engineer, Mark helps customers embrace graph data and Neo4j building sophisticated solutions to challenging data problems. When he's not with customers Mark is a developer on Neo4j and writes his experiences of being a graphista on a popular blog at http://markhneedham.com/blog. He tweets at @markhneedham. Mark is a DZone MVB and is not an employee of DZone and has posted 527 posts at DZone. You can read more from them at their website. View Full User Profile

There's No Such Thing As a DevOps Team?

12.05.2012
| 4016 views |
  • submit to reddit

A few weeks ago Jez Humble wrote a blog post titled “There’s no such thing as a ‘DevOps team’” where he explains what DevOps is actually supposed to be about and describes a model of how developers and operations folk can work together.

Jez’s suggestion is for developers to take responsibility for the systems they create but he notes that:

[...] they need support from operations to understand how to build reliable software that can be continuous deployed to an unreliable platform that scales horizontally. They need to be able to self-service environments and deployments. They need to understand how to write testable, maintainable code. They need to know how to do packaging, deployment, and post-deployment support.

His suggestions sound reasonably similar to the way Spotify have their teams setup whereby product teams own their product from idea to production but can get help from an operations team to make this happen.

At Spotify there is a separate operations team, but their job is not to make releases for the squads – their job is to give the squads the support they need to release code themselves; support in the form of infrastructure, scripts, and routines. They are, in a sense, “building the road to production”.

It’s an informal but effective collaboration, based on face-to-face communication rather than detailed process documentation.

On a few of projects that I’ve worked on in the last 18 months or so we’ve tried to roughly replicate this model but there are a few challenges in doing so.

Silo Mentality

In a number of the organisations that I’ve worked at there is a mentality that people should only take responsibility for ‘their bit’ which in this case means developers code the application and operations deploy it.

This manifests itself when you hear comments such as “it must be an application problem” when something isn’t working rather than working together to solve the problem.

There’s also a more subtle version of this when we get into the belief that developers are only responsible for putting points on the board therefore they shouldn’t spend time doing operations-y work.

Release Pressure

Even if we’ve got beyond the idea that people should only be responsible for their silo and have operations and developers working closely together it can still end up reverting back to type when people are under pressure.

When a big release is coming up there’ll often be a push to ensure that the expected features have been completed and this leads us back towards the silo mentality, at least temporarily.

Presumably with a more frequent release schedule this becomes less of an issue but I haven’t worked for long enough in that way to say for sure.

Security Concerns

In some environments there is often quite tight security around who is allowed to push into production and this would typically be folks in the operations team.

Obviously this means that the product team can’t actually push their own changes unless they arrange to work together with one of the operations folks to do so.

We still don’t have the ‘throw it over the wall’ mentality in this setup but it does create more of a bottle neck in the system than we’d have otherwise.

In Summary

These are just some of the obstacles that I’ve seen that can get in the way of our optimal setup.

I’m sure there are others that I haven’t come across yet but the nice thing is that two of these are more a mindset thing than anything else so that can be fixed over time.



Published at DZone with permission of Mark Needham, author and DZone MVB.

(Note: Opinions expressed in this article and its replies are the opinions of their respective authors and not those of DZone, Inc.)

Comments

michael wolfe replied on Wed, 2012/12/05 - 11:50pm

 the developers should be responsible for how the programs are run as well as the dependencies that each program needs to run. the developers often write production scripts that accompany the programs. the ops staff should be in charge of actually deploying the apps, having data sets in data bases restored or filled with test or production data as requested by the programmer. yes typically ops and developers work together in trying to insure production runs as well as expected. on the other hand, the main concern of the developer is insuring that the code is stable, making additional changes and enhancements as needed. they cannot afford to spend so much time on ops and production tasks. it is the full-time job of the ops staff to take care of those tasks. essentially ops serve the developers and developers need ops to carry out requests. so developers stay on good terms with the ops staff!

Comment viewing options

Select your preferred way to display the comments and click "Save settings" to activate your changes.