Earlier this month we held the third annual Opscode Community Summit. There, we shared some lessons we’ve learned about publishing and maintaining community cookbooks. For those that could not be there, we’d like to share them with you as well.
Over the years, thoughts and attitudes about what cookbooks are and how they should be treated have evolved. In the beginning, everyone wrote their cookbooks from scratch to manage their infrastructure. This is the simplest use case for Chef users, and remains the most popular. Every organization is different, and comes with unique requirements, culture, history and challenges.
Early on, we introduced the Opscode Community site and encouraged our community to share. This was a huge success, and changed the way people thought about cookbooks. The community site has turned into a public artifact repository, and currently serves 1198 cookbooks from thousands of contributors all over the world.
Opscode has been maintaining a number of these cookbooks. One thing we’ve discovered is that when they’re awesome, its usually because they fall into one of three categories. First, they do the easy thing and behave the way one would expect on a particular platform. Second, they’ve grown to encompass many possible configuration scenarios across many different platforms, usually bending some idioms along the way. Third, they provide robust, easy to use libraries that expose custom resources and providers that users can consume as primitives in their own recipes.
Most of the cookbooks that Opscode maintains have drifted towards the category two. That’s great for a user that’s both an expert in Chef, as well as the technology represented in a given cookbook. However, most users do not fit that profile. The third scenario is more ideal.
As it turns out, we are not domain experts in all the technologies many of our cookbooks represent. This means we’ve become a roadblock in the development of many of these projects. Nobody likes roadblocks.
After careful consideration, we’ve decided that the best thing to do for the cookbook ecosystem is to seek out trusted maintainers with domain expertise in the technologies embodied in the various projects. This will allow us to focus on building primitives; libraries, resources, providers, and well engineered content for new Chef users.
We are still very much in the cookbook game. We’re just making the game better. As we set many our cookbooks free, we’ll maintain contributor status, but no longer play the role of primary maintainer. This decentralization will ease the friction associated with contributing patches, and allow each cookbook to reach its full potential.
We will be holding onto cookbooks that represent the core building blocks that we use at our customer sites every day. These will serve as reference cookbooks for others to use as examples. Sharpening our focus will help us to make each one the best it can be.
2014 is going to be an exciting year for Chef.
May the Source be with you.
-s