A node is any physical, virtual, or cloud machine that is configured to be maintained by a chef-client. A bootstrap is a process that installs the chef-client on a target system so that it can run as a chef-client and communicate with a Chef server. There are two ways to do this:
knife bootstrap
subcommand to bootstrap a node using the omnibus installer
The knife bootstrap
command is a common way to install the chef-client on a node. The default for this approach assumes that a node can access the Chef website so that it may download the chef-client package from that location.
The omnibus installer will detect the version of the operating system, and then install the appropriate version of the chef-client using a single command to install the chef-client and all of its dependencies, including an embedded version of Ruby, RubyGems, OpenSSL, key-value stores, parsers, libraries, and command line utilities.
The omnibus installer puts everything into a unique directory (/opt/chef/
) so that the chef-client will not interfere with other applications that may be running on the target machine. Once installed, the chef-client requires a few more configuration steps before it can perform its first chef-client run on a node.
Run the bootstrap command
The knife bootstrap
subcommand is used to run a bootstrap operation that installs the chef-client on the target node. The following steps describe how to bootstrap a node using knife.
Identify the FQDN or IP address of the target node. The knife bootstrap
command requires the FQDN or the IP address for the node in order to complete the bootstrap operation.
Once the workstation machine is configured, it can be used to install the chef-client on one (or more) nodes across the organization using a knife bootstrap operation. The knife bootstrap
command is used to SSH into the target machine, and then do what is needed to allow the chef-client to run on the node. It will install the chef-client executable (if necessary), generate keys, and register the node with the Chef server. The bootstrap operation requires the IP address or FQDN of the target system, the SSH credentials (username, password or identity file) for an account that has root access to the node, and (if the operating system is not Ubuntu, which is the default distribution used by knife bootstrap
) the operating system running on the target system.
In a command window, enter the following:
$ knife bootstrap 123.45.6.789 -x username -P password --sudo
where 123.45.6.789
is the IP address or the FQDN for the node. Use the --distro
option to specify a non-default distribution. For more information about the options available to the knife bootstrap
command for Ubuntu- and Linux-based platforms, see knife bootstrap. For Microsoft Windows, the knife windows
plugin is required, see knife windows .
And then while the bootstrap operation is running, the command window will show something like the following:
Bootstrapping Chef on 123.45.6.789 123.45.6.789 knife sudo password: Enter your password: 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:05 -0700] INFO: *** Chef 10.12.0 *** 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:07 -0700] INFO: Client key /etc/chef/client.pem is not present - registering 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Setting the run_list to [] from JSON 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Run List is [] 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Run List expands to [] 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Starting Chef Run for name_of_node 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Running start handlers 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:15 -0700] INFO: Start handlers complete. 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:17 -0700] INFO: Loading cookbooks [] 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:17 -0700] WARN: Node name_of_node has an empty run list. 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:19 -0700] INFO: Chef Run complete in 3.986283452 seconds 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:19 -0700] INFO: Running report handlers 123.45.6.789 123.45.6.789 [Fri, 07 Sep 2012 11:05:19 -0700] INFO: Report handlers complete 123.45.6.789
After the bootstrap operation has finished, verify that the node is recognized by the Chef server. To show only the node that was just bootstrapped, run the following command:
$ knife client show name_of_node
where name_of_node
is the name of the node that was just bootstrapped. The Chef server will return something similar to:
admin: false chef_type: client json_class: Chef::ApiClient name: name_of_node public_key:
and to show the full list of nodes (and workstations) that are registered with the Chef server, run the following command:
knife client list
The Chef server will return something similar to:
workstation workstation ... client name_of_node ... client
The ORGANIZATION-validator.pem is typically added to the .chef directory on the workstation. When a node is bootstrapped from that workstation, the ORGANIZATION-validator.pem is used to authenticate the newly-created node to the Chef server during the initial chef-client run. Starting with chef-client version 12.1, it is possible to bootstrap a node using the USER.pem file instead of the ORGANIZATION-validator.pem file. This is known as a “validatorless bootstrap”.
To create a node via the USER.pem file, simply delete the ORGANIZATION-validator.pem file on the workstation. For example:
$ rm -f /home/lamont/.chef/myorg-validator.pem
and then make the following changes in the knife.rb file:
validation_client_name
settingvalidation_key
setting to be something that isn’t a path to an existent ORGANIZATION-validator.pem file. For example: /nonexist
.As long as a USER.pem is also present on the workstation from which the validatorless bootstrap operation will be initiated, the bootstrap operation will run and will use the USER.pem file instead of the ORGANIZATION-validator.pem file.
When running a validatorless knife bootstrap
operation, the output is similar to:
desktop% knife bootstrap 10.1.1.1 -N foo01.acme.org \ -E dev -r 'role[base]' -j '{ "foo": "bar" }' \ --ssh-user vagrant --sudo Node foo01.acme.org exists, overwrite it? (Y/N) Client foo01.acme.org exists, overwrite it? (Y/N) Creating new client for foo01.acme.org Creating new node for foo01.acme.org Connecting to 10.1.1.1 10.1.1.1 Starting first Chef Client run... [....etc...]
Use the following options with a validatorless bootstrap to specify items that are stored in chef-vault:
--bootstrap-vault-file VAULT_FILE
--bootstrap-vault-item VAULT_ITEM
vault:item
.--bootstrap-vault-json VAULT_JSON
A JSON string that contains a list of vaults and items to be updated.
For example:
--bootstrap-vault-json '{ "vault1": ["item1", "item2"], "vault2": "item2" }'
The --bootstrap-vault-*
options add the client identify of the bootstrapping node to the permissions list of the specified vault item. This enables the newly-bootstrapped chef-client to be able to read items from the vault. Only a single client is authorized at a time for acces to the vault. (The -S
search query option with the knife vault create
subcommand does the same.)
The following example shows how to recreate a data bag item:
$ knife vault delete sea power Do you really want to delete sea/power? (Y/N) Y Deleted chef_vault_item[sea/power] $ echo "{\"some\":\"content for them\"}" > sea-power-content.json $ cat sea-power-content.json {"some":"content for them"} $ knife vault create sea power -M client -A sean_horn,angle -J sea-power-content.json
No clients, because the -S
option was not specified while creating the vault.
At this time, only the users sean_horn
and angle
are authorized to read and manage the vault.
$ knife vault show sea power --mode client -p all admins: sean_horn angle clients: id: power search_query: some: content for them
It is definitely an encrypted databag, see?
$ knife data_bag show sea power WARNING: Encrypted data bag detected, but no secret provided for decoding. Displaying encrypted data. id: power some: cipher: aes-256-cbc encrypted_data: c7Axnyg+1KDxBPOZdYN9QuIYx6dmSmK70unAQbn12Lygvsv2g9DPJJbueXVh +yxL iv: ONoVR7OjPZiAzaqOZ30bjg== version: 1
Use the sea:power
recreation step above first, to follow the difference in the vault permissions.
echo "{\"sea\":\"power\"}" > sea-power-bootstrap-vault-file.json $ knife bootstrap localhost -p 2200 -N ubuntu-12.04 -r 'role[group1]' --ssh-user vagrant --sudo --bootstrap-vault-file sea-power-bootstrap-vault-file.json Node ubuntu-12.04 exists, overwrite it? (Y/N) Y Client ubuntu-12.04 exists, overwrite it? (Y/N) Y Creating new client for ubuntu-12.04 Creating new node for ubuntu-12.04 Connecting to localhost localhost -----> Existing Chef installation detected localhost Starting first Chef Client run... localhost Starting Chef Client, version 12.2.1 localhost resolving cookbooks for run list: ["delay-test-reporting"] localhost Synchronizing Cookbooks: localhost - delay-test-reporting localhost Compiling Cookbooks... localhost Converging 1 resources localhost Recipe: delay-test-reporting::default localhost * execute[sleep 30] action run localhost - execute sleep 30 localhost localhost Running handlers: localhost Running handlers complete localhost Chef Client finished, 1/1 resources updated in 34.307257232 seconds
The client ubuntu-12.04
was added to the chef-vault
during the bootstrap.
$ knife vault show sea power --mode client -p all admins: sean_horn angle clients: ubuntu-12.04 id: power search_query: some: content for them
Use the sea:power
re-creation step above first, to follow the difference in the vault permissions.
$ knife bootstrap localhost -p 2200 -N ubuntu-12.04 -r 'role[group1]' --ssh-user vagrant --sudo --bootstrap-vault-item sea:power Node ubuntu-12.04 exists, overwrite it? (Y/N) Y Client ubuntu-12.04 exists, overwrite it? (Y/N) Y Creating new client for ubuntu-12.04 Creating new node for ubuntu-12.04 Connecting to localhost localhost -----> Existing Chef installation detected localhost Starting first Chef Client run... localhost Starting Chef Client, version 12.2.1 localhost resolving cookbooks for run list: ["delay-test-reporting"] localhost Synchronizing Cookbooks: localhost - delay-test-reporting localhost Compiling Cookbooks... localhost Converging 1 resources localhost Recipe: delay-test-reporting::default localhost * execute[sleep 30] action run localhost - execute sleep 30 localhost localhost Running handlers: localhost Running handlers complete localhost Chef Client finished, 1/1 resources updated in 34.322229474 seconds
During the above run, the sea:power
vault item was updated with the ubuntu-12.04
client during the validatorless bootstrap. Previously, it only had the two admins authorized to view the content
$ knife vault show sea power -p all admins: sean_horn angle clients: ubuntu-12.04 id: power search_query: role:stuff some: secret stuff for them
Then, let’s check the ubuntu-12.04
client. Install the chef-vault
gem in the embedded chef-client:
$ sudo /opt/chef/embedded/bin/gem install chef-vault --no-ri --no-rdoc Fetching: chef-vault-2.6.1.gem (100%) Successfully installed chef-vault-2.6.1 1 gem installed
The client itself can decrypt and read the encrypted databag contents as well.
$ sudo /opt/chef/bin/knife vault show sea power -c /etc/chef/client.rb -M client -p all admins: sean_horn angle clients: ubuntu-12.04 id: power search_query: role:group1 some: secret stuff for them
Success! The client is authorized to view the content of the sea:power
databag item
Use the sea:power
re-creation step above first, to follow the difference in the vault permissions.
$ knife bootstrap localhost -p 2200 -N ubuntu-12.04 -r 'role[group1]' --ssh-user vagrant --sudo --bootstrap-vault-json '{"sea": "power"}' Node ubuntu-12.04 exists, overwrite it? (Y/N) Y Client ubuntu-12.04 exists, overwrite it? (Y/N) Y Creating new client for ubuntu-12.04 Creating new node for ubuntu-12.04 Connecting to localhost localhost -----> Existing Chef installation detected localhost Starting first Chef Client run... localhost Starting Chef Client, version 12.2.1 localhost resolving cookbooks for run list: ["delay-test-reporting"] localhost Synchronizing Cookbooks: localhost - delay-test-reporting localhost Compiling Cookbooks... localhost Converging 1 resources localhost Recipe: delay-test-reporting::default localhost * execute[sleep 30] action run localhost - execute sleep 30 localhost localhost Running handlers: localhost Running handlers complete localhost Chef Client finished, 1/1 resources updated in 33.732784033 seconds
$ knife vault show sea power -M client -p all admins: sean_horn angle clients: ubuntu-12.04 id: power search_query: some: content for them
The chef-client can be installed using an unattended bootstrap. This allows the chef-client to be installed from itself, without using SSH. For example, machines are often created using environments like AWS Auto Scaling, AWS CloudFormation, Rackspace Auto Scale, and PXE. In this scenario, using tooling for attended, single-machine installs like knife bootstrap
or knife CLOUD_PLUGIN create
is not practical because the machines are created automatically and someone cannot always be on-hand to initiate the bootstrap process.
When the chef-client is installed using an unattended bootstrap, remember that the chef-client:
When the chef-client is installed using an unattended bootstrap, it is typically built into an image that starts the chef-client on boot. The type of image used depends on the platform on which the unattended bootstrap will take place.
Use settings in the client.rb file—chef_server_url
, http_proxy
, and so on—to ensure that configuration details are built into the unattended bootstrap process.
Setting the initial run-list
A node’s initial run-list is specified using a JSON file on the host system. When running the chef-client as an executable, use the -j
option to tell the chef-client which JSON file to use. For example:
$ chef-client -j /etc/chef/file.json --environment _default
where file.json
is similar to:
{ "resolver": { "nameservers": [ "10.0.0.1" ], "search":"int.example.com" }, "run_list": [ "recipe[resolver]" ] }
and where _default
is the name of the environment that is assigned to the node.
Warning
This approach may be used to update normal
attributes, but should never be used to update any other attribute type, as all attributes updated using this option are treated as normal
attributes.
© Chef Software, Inc.
Licensed under the Creative Commons Attribution 3.0 Unported License.
The Chef™ Mark and Chef Logo are either registered trademarks/service marks or trademarks/servicemarks of Chef, in the United States and other countries and are used with Chef Inc's permission.
We are not affiliated with, endorsed or sponsored by Chef Inc.
https://docs-archive.chef.io/release/12-13/install_bootstrap.html