Skip to content

Latest commit

 

History

History
274 lines (234 loc) · 10.7 KB

part_a.md

File metadata and controls

274 lines (234 loc) · 10.7 KB

Part A: CREATE a Base Policyfile

Step 1: Create a base policyfile

The base policyfile will be used by all the nodes.

Run the following command in the directory C:\chef-repo\policyfiles. If the directory does not exist, create it:

$ chef generate policyfile base

Your output will look like this:

C:\Users\chef\cookbooks\policyfiles> chef generate policyfile base
Recipe: code_generator::policyfile
  * template[C:/Users/chef/cookbooks/policyfiles/base.rb] action create
    - create new file C:/Users/chef/cookbooks/policyfiles/base.rb
    - update content in file C:/Users/chef/cookbooks/policyfiles/base.rb from none to 533141
    (diff output suppressed by config)
C:\Users\chef\cookbooks\policyfiles>

Now edit the file

$ code base.rb

In Visual Studio Code, create the following:

# base.rb - Describe how you want Chef to build your system.
#
# For more information on the Policyfile feature, visit
# https://github.com/opscode/chef-dk/blob/master/POLICYFILE_README.md

# A name that describes what the system you're building with Chef does.
name 'base'

# Where to find external cookbooks:
default_source :supermarket

# Specify a custom source for a cookbook:
cookbook 'chef-client', git: 'https://github.com/anthonygrees/chef-client.git'
cookbook 'audit_agr', git: 'https://github.com/anthonygrees/audit_agr.git'

# run_list: chef-client will run these recipes in the order specified.
run_list 'audit_agr', 'chef-client'

The cookbook source could be from public supermarket, private supermarket, a chef server, a local repo or even an artifact repo. Here are some examples:

default_source :supermarket  # Public Supermarket
default_source :supermarket, "https://mysupermarket.example"  # Private Supermarkey
default_source :chef_server, "https://chef-server.example/organizations/example"
default_source :chef_repo, "path/to/repo"
default_source :artifactory, "https://artifactory.example/api/chef/my-supermarket

Step 2: Generate the lock file

With our basic base.rb policyfile, we run chef install to fetch dependencies and generate a base.lock.json.

So run the following command:

$ chef install base.rb

and you will see the following output

C:\Users\chef\cookbooks\policyfiles> chef install base.rb
Building policy base
Expanded run list: recipe[audit_agr], recipe[chef-client]
Caching Cookbooks...
Installing chef-client >= 0.0.0 from git
Installing audit_agr   >= 0.0.0 from git
Installing cron        6.2.1
Installing logrotate   2.2.0
Installing windows     5.2.3
Installing audit       7.3.0

Lockfile written to C:/Users/chef/cookbooks/policyfiles/base.lock.json
Policy revision id: f458a363e1ed148676a5ee5c9a558cb0dd3ba8581803de44de49ccd7b1d5e134
C:\Users\chef\cookbooks\policyfiles>

Step 3: Let's take a look at the lock file

Let’s take a look at the base.lock.json we just created. We’ll go over each part individually:

Run the collowing command:

$ code .

This will show us the base.lock.json file

Revision ID

Each time we create or update the lock, chef will automatically generate a revision_id based on the content. These values are used to automatically version your policies, so that you can apply different revsions of a policy to different set of servers. We’ll see this in action a little later.

"revision_id": "5f750bf464100b487cd7c276c5d532341b79fbeb5e8accd29538ae972896992b"
Name and Run List

The lock includes the name and run list we specified previously. The run list is normalized to the least ambiguous form.

In this example, you will see that it has selected the default recipe for both of the cookbooks.

"run_list": [
    "recipe[audit_agr::default]",
    "recipe[chef-client::default]"
Cookbook Locks

For each cookbook we use, there is a corresponding entry in the cookbook_locks section. The exact data collected about each cookbook is dependent on the cookbook’s source. In this case, we have a cookbook sourced from GitHub which is a git repo. In the event we need to debug this cookbook later, ChefDK has collected information about the cookbook’s git revision.

You will notice that it has included more cookbooks than we specified. This is because the audit and chef_client cookbooks have dependent cookbooks. The policyfile tracks each and every one!

  "cookbook_locks": {
    "audit": {
      "version": "7.3.0",
      "identifier": "ec19259446ed7259f898861c30d1b106d649616f",
      "dotted_decimal_identifier": "66455743695875442.25324606895960273.194642923053423",
      "cache_key": "audit-7.3.0-supermarket.chef.io",
      "origin": "https://supermarket.chef.io:443/api/v1/cookbooks/audit/versions/7.3.0/download",
      "source_options": {
        "artifactserver": "https://supermarket.chef.io:443/api/v1/cookbooks/audit/versions/7.3.0/download",
        "version": "7.3.0"
      }
    },
    "audit_agr": {
      "version": "2.2.2",
      "identifier": "997012b6a9e2488cfead390e2fdf26821a3cf3cf",
      "dotted_decimal_identifier": "43188897113039432.39686516679520223.42340227806159",
      "cache_key": "audit_agr-de245088a67ed9a178e39ad33b9868d95c0a20df",
      "origin": "https://github.com/anthonygrees/audit_agr.git",
      "source_options": {
        "git": "https://github.com/anthonygrees/audit_agr.git",
        "revision": "de245088a67ed9a178e39ad33b9868d95c0a20df"
      }
    },
    "chef-client": {
      "version": "10.2.2",
      "identifier": "665de50495d89d717cd73c0cf68a15a847a621d8",
      "dotted_decimal_identifier": "28813685830310045.31943936235599498.23812500759000",
      "cache_key": "chef-client-65efbdbc8d8df7077378974a07455be06699708d",
      "origin": "https://github.com/anthonygrees/chef-client.git",
      "source_options": {
        "git": "https://github.com/anthonygrees/chef-client.git",
        "revision": "65efbdbc8d8df7077378974a07455be06699708d"
      }
    },
    "cron": {
      "version": "6.2.1",
      "identifier": "08676b5cc33658430ce04cecc16dd07200380e83",
      "dotted_decimal_identifier": "2365510629144152.18872980942405997.229188048522883",
      "cache_key": "cron-6.2.1-supermarket.chef.io",
      "origin": "https://supermarket.chef.io:443/api/v1/cookbooks/cron/versions/6.2.1/download",
      "source_options": {
        "artifactserver": "https://supermarket.chef.io:443/api/v1/cookbooks/cron/versions/6.2.1/download",
        "version": "6.2.1"
      }
    },
    "logrotate": {
      "version": "2.2.0",
      "identifier": "53e09234a4f73cc13f46d833d2e5075cafddfaa8",
      "dotted_decimal_identifier": "23609341620057916.54394244012692197.8094668946088",
      "cache_key": "logrotate-2.2.0-supermarket.chef.io",
      "origin": "https://supermarket.chef.io:443/api/v1/cookbooks/logrotate/versions/2.2.0/download",
      "source_options": {
        "artifactserver": "https://supermarket.chef.io:443/api/v1/cookbooks/logrotate/versions/2.2.0/download",
        "version": "2.2.0"
      }
    },
    "windows": {
      "version": "5.2.3",
      "identifier": "b9450a2483840dd3f3e9044b17eb8c5c2fec3178",
      "dotted_decimal_identifier": "52148780556059661.59659402210908139.154327568888184",
      "cache_key": "windows-5.2.3-supermarket.chef.io",
      "origin": "https://supermarket.chef.io:443/api/v1/cookbooks/windows/versions/5.2.3/download",
      "source_options": {
        "artifactserver": "https://supermarket.chef.io:443/api/v1/cookbooks/windows/versions/5.2.3/download",
        "version": "5.2.3"
      }
    }
  },
Attributes

Policyfiles can have attributes that replace role attributes. We’ll see these a little later.

"default_attributes": {

  },
  "override_attributes": {

  },
Solution Dependencies

You can ignore the solution_dependencies section. It’s used to keep track of dependencies in your cookbooks so ChefDK can check whether changes to your cookbooks are compatible with their dependencies without having to download the full cookbook list from supermarket every time.

"default_attributes": {

  },
  "override_attributes": {

  },

Step 4: Upload the policyfile to the Chef Server

To do this we need to understand about policy_groups. A policy group is essentially an environment and allows you to assign multiple nodes to the group of policies.

Promote to the Development Policy Group

Let's upload the policyfile to the Chef Server and add it to the Policy Group of dev_dc1 for development in Data Center 1.

To do this, we use the chef push subcommand to upload an existing Policyfile.lock.json file to the Chef server, along with all of the cookbooks that are contained in the file. The base.lock.json file will be applied to the specified policy group, which is a set of nodes that share the same run-list and cookbooks.

$ chef push dev_dc1 base.rb

Your output will look something like this:

C:\Users\chef\cookbooks\policyfiles> chef push dev_dc1 base.rb
Uploading policy to policy group dev_dc1
Uploaded audit       7.3.0  (ec192594)
Uploaded audit_agr   2.2.2  (997012b6)
Uploaded chef-client 10.2.2 (665de504)
Uploaded cron        6.2.1  (08676b5c)
Uploaded logrotate   2.2.0  (53e09234)
Uploaded windows     5.2.3  (b9450a24)
C:\Users\chef\cookbooks\policyfiles>
Promote to the System Test Policy Group

Your testing in dev_dc1 has passed. Let's promote to policy group sys_dc1.

$ chef push sys_dc1 base.rb
Promote to the Production Test Policy Group

Your testing in sys_dc1 has passed. Let's promote to policy group prod_dc1.

$ chef push prod_dc1 base.rb
How do you know which Policy is on a Chef Server ?

Use the chef show-policy subcommand to display revisions for every base.rb file that is on the Chef server. By default, only active policy revisions are shown. When both a policy and policy group are specified, the contents of the active base.lock.json file for the policy group is returned.

$ chef show-policy base

Each policy in each policy group is the same. Your output will look something like this:

C:\Users\chef\cookbooks\policies> chef show-policy
base
====

* dev_dc1:   aa65b40c43
* prod_dc1:  aa65b40c43
* sys_dc1:   aa65b40c43

C:\Users\chef\cookbooks\policies>
Compare with chef diff

Use the chef diff subcommand to display an itemized comparison of two revisions of a Policyfile.lock.json file.

Run the following command to see the difference between Development DC1 and Production DC1

$ chef diff .\base.lock.json dev_dc1...prod_dc1

Your output will look something like this. There are no changes to display:

C:\Users\chef\cookbooks\policies> chef diff .\base.lock.json dev_dc1...prod_dc1
No changes for policy lock 'base' between 'policy_group:dev_dc1' and 'policy_group:prod_dc1'
C:\Users\chef\cookbooks\policies>