Chef (software)

Chef is a company and the name of a configuration management tool written in Ruby and Erlang. It uses a pure-Ruby, domain-specific language (DSL) for writing system configuration "recipes". Chef is used to streamline the task of configuring and maintaining a company's servers, and can integrate with cloud-based platforms such as Internap, Amazon EC2, Google Cloud Platform, Oracle Cloud, OpenStack, SoftLayer, Microsoft Azure, and Rackspace to automatically provision and configure new machines. Chef contains solutions for both small and large scale systems, with features and pricing for the respective ranges.

Chef
Developer(s)Chef
Initial releaseJanuary 2009 (2009-01)[1]
Stable release
  • 2019-01-28 14.10.9 (client),[2]
  • 2018-10-15 12.18.14 (server)[3]
Repositorygithub.com/chef/chef
Written inRuby (client) and Ruby / Erlang (server)
Operating systemGNU/Linux, AT&T Unix, MS Windows, FreeBSD, Mac OS X, IBM AIX illumos
TypeConfiguration management, System administration, Network management, Cloud management, Continuous delivery, DevOps, Infrastructure as Code
LicenseApache License 2.0
Websitewww.chef.io

Features

The user writes "recipes" that describe how Chef manages server applications and utilities (such as Apache HTTP Server, MySQL, or Hadoop) and how they are to be configured. These recipes (which can be grouped together as a "cookbook" for easier management) describe a series of resources that should be in a particular state: packages that should be installed, services that should be running, or files that should be written. These various resources can be configured to specific versions of software to run and can ensure that software is installed in the correct order based on dependencies. Chef makes sure each resource is properly configured and corrects any resources that are not in the desired state.[4]

Chef can run in client/server mode, or in a standalone configuration named "chef-solo". In client/server mode, the Chef client sends various attributes about the node to the Chef server. The server uses Elasticsearch to index these attributes and provides an API for clients to query this information. Chef recipes can query these attributes and use the resulting data to help configure the node.

Traditionally, Chef was used to manage Linux but later versions support Microsoft Windows as well.[5]

It is one of the major configuration management systems on Linux, along with CFEngine, Ansible and Puppet.[6][7] More than a configuration management tool, Chef, along with Puppet and Ansible, is one of the industry's most notable Infrastructure as Code (IAC) tools.[8]

History

Chef was created by Adam Jacob as a tool for his consulting company, whose business model was to build end-to-end server/deployment tools. Jacob showed Chef to Jesse Robbins, who saw its potential after running operations at Amazon. They founded a new company with Barry Steinglass, Nathen Haneysmith, and Joshua Timberman to turn Chef into a product.[9]

The project was originally named "marionette", but the word was too long and cumbersome to type; the "recipe" format that the modules were prepared in led to the project being renamed "Chef".[9]

In February 2013, Opscode released version 11 of Chef. Changes in this release included a complete rewrite of the core API server in Erlang.[10]

On April 2, 2019, the company announced that all their products are now open source under the Apache 2.0 license.[11]

Platform support

Chef is supported on multiple platforms according to a supported platforms matrix for client and server products.[12] Major platform support for clients includes AIX, RHEL/CentOS, FreeBSD, OS X, Solaris, Microsoft Windows and Ubuntu. Additional client platforms include Arch Linux, Debian and Fedora. Chef Server is supported on RHEL/CentOS, Oracle Linux, Oracle Cloud and Ubuntu.

Customers

Chef is used by Facebook,[13], AWS OpsWorks, the HP Public Cloud[14], Prezi[15], BlackLine, and U.S. Immigration and Customs Enforcement.[16]

See also

References

  1. "Announcing Chef". chef.io. 15 January 2009. Retrieved 9 January 2017.
  2. Tim Smith (2019-01-28). "Chef 14.10.9 Released!". chef.io. Retrieved 2019-01-28.
  3. Mark Anderson (2018-10-15). "Chef Server 12.18.14 Release". chef.io. Retrieved 2018-11-08.
  4. Chef - Code Can | Chef, retrieved 2015-07-04
  5. Cade Metz (2011-10-26), "The Chef, the Puppet, and the Sexy IT Admin", Wired, retrieved 2015-07-04
  6. Alan Sharp-Paul (2013-03-04), Puppet vs. Chef - The Battle Wages On, retrieved 2015-07-04.
  7. Lueninghoener, Cory (2011-03-28), "Getting Started with Configuration Management" (PDF), ;login:, Usenix, 36 (2), retrieved 2015-07-04
  8. Keiser, John (14 November 2016). "Chef Provisioning: Infrastructure As Code".
  9. History of Chef: What's in a Name? on YouTube
  10. Bryan McLellan (2013-02-04). "Chef 11 Released!". Chef (company). Retrieved 2015-07-04.
  11. Introducing the New Chef: 100% Open, Always - Chef Blog
  12. "Platforms — Chef Docs". chef.io. Retrieved 9 January 2017.
  13. "Facebook uses a seasoned Chef to keep servers simmering". pcadvisor.co.uk. Retrieved 6 January 2014.
  14. "ChefConf Readout: Chef to Enable the Full Continuous Deployment Pipeline". HPCloud.com. Archived from the original on 4 March 2014. Retrieved 22 March 2017.CS1 maint: BOT: original-url status unknown (link)
  15. How Chef Enables the DevOps Culture at Prezi - Zsolt Dollenstein on YouTube
  16. "A Personal Message From the CTO". Chef Blog. 2019-09-20. Retrieved 2019-09-21.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.