1 # OpenStreetMap chef cookbooks
3 [![Build Status](https://travis-ci.org/openstreetmap/chef.svg?branch=master)](https://travis-ci.org/openstreetmap/chef)
5 This repository manages the configuration of all the servers run by the
6 OpenStreetMap Foundation's Operations Working Group. We use
7 [Chef](https://www.chef.io/) to automated the configuration of all of our
12 We make extensive use of roles to configure the servers. In general we have:
14 ## Server-specific roles (e.g. [katla.rb](roles/katla.rb))
16 These deal with particular setup or quirks of a server, such as its IP address. They also include roles representing the service they are performing, and the location they are in and any particular hardware they have that needs configuration.
17 All our servers are [named after dragons](http://wiki.openstreetmap.org/wiki/Servers/Name_Ideas).
19 ## Hardware-specific roles (e.g. [tyan-s7010.rb](roles/tyan-s7010.rb))
21 Covers anything specific to a certain piece of hardware, like a motherboard, that could apply to multiple machines.
23 ## Location-specific roles (e.g. [ic.rb](roles/ic.rb))
25 These form a hierarchy of datacentres, organisations, and countries where our servers are located.
27 ## Service-specific roles (e.g. [web-frontend](roles/web-frontend.rb))
29 These cover the services that the server is running, and will include the recipes required for that service along with any specific configurations and other cascading roles.
33 We use the 'Organization Repository' approach, where we have all our cookbooks in this repository (as opposed to one repository per cookbook). Additionally we don't make use of external cookbooks so every cookbook required is in this repository
37 Contributions are welcome! Please see [CONTRIBUTING.md](CONTRIBUTING.md) for more details.