+++ title = "Airgapped Installation"
draft = false
gh_repo = "automate"
[menu] [menu.automate] title = "Airgapped Installation" parent = "automate/getting_started" identifier = "automate/getting_started/airgapped_installation.md Airgapped Installation" weight = 40 +++
An airgapped host is one that has no direct inbound or outbound internet
traffic.
To install or upgrade Chef Automate on an airgapped host, you will need to create an Airgap Installation Bundle (.aib
) on an internet-connected host and then transfer both the Airgap Installation Bundle and the chef-automate
binary that you used to create it to the airgapped host for use.
To get a trial license for an airgapped host contact Chef.
On an internet-connected host, download the Chef Automate command-line tool and use it to prepare an Airgap Installation Bundle.
Download the Chef Automate command-line tool from the current
[release channel]({{< relref "install.md#release-channels" >}}).
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
To download and bundle the software included in the most recent Chef Automate release, run:
./chef-automate airgap bundle create
To download and bundle the software included in a specific Chef Automate release, run
./chef-automate airgap bundle create --version VERSION
These commands produce an Airgap Installation Bundle named:
automate-<timestamp>.aib
.
Transfer the chef-automate
binary and the Airgap Installation Bundle to the airgapped host.
Save the Chef Automate command-line tool in a directory that is NOT in $PATH. The Chef Automate installation process puts a copy of chef-automate
into /bin
and manages it.
sudo ./chef-automate init-config --upgrade-strategy none
creates a config.toml
file with default values. Setting an upgrade strategy of none
prevents Chef Automate from checking its release channel for updates via the internet.
Edit config.toml
to make changes to FQDN and other configuration settings. See
[Configuring Chef Automate]({{< relref "configuration.md" >}}) for more information on configuration settings.
sudo ./chef-automate deploy config.toml --airgap-bundle </path/to/airgap-install-bundle>
Deploying Chef Automate takes ten minutes for a clean install.
At the command prompt, accept the terms of service with a y
, The installer then performs a series of pre-flight checks. Any
unsuccessful checks offer information for resolving issues or skipping the check.
After resolving any pre-flight issues, run the deploy command again.
At the end of the deployment process you will see:
Deploy complete
The deployment process writes login credentials to the automate-credentials.toml
in your current working directory.
Navigate to https://{{< example_fqdn "automate" >}}
in a browser and log in to Chef Automate with
the credentials provided in automate-credentials.toml
.
Once you log in, Chef Automate prompts you for a license.
To send data from your Chef Infra Server or Chef Infra Clients to Chef Automate 2, the process is the same as Chef Automate 1. See [Configure Data Collection]({{< relref "data_collection.md" >}}) for more information.
We've committed to ensuring the stability of the upgrade and to supporting Chef Automate's automatic upgrades. To upgrade an airgapped install, you must supply an airgap bundle.
On an internet-connected host, follow the steps in [Create an Airgap Installation Bundle]({{< relref "#create-an-airgap-installation-bundle" >}}) to upgrade your Chef Automate command-line tool and prepare an Airgap Installation Bundle. Transfer the bundle and Chef Automate command-line tool to the airgapped host and run:
sudo chef-automate upgrade run --airgap-bundle </path/to/bundle>
If you are unable to open Chef Automate, check that the config.toml
contains the host's public DNS name as the FQDN.
# This is a default Chef Automate configuration file. You can run
# 'chef-automate deploy' with this config file and it should
# successfully create a new Chef Automate instance with default settings.
[global.v1]
# The external fully qualified domain name.
# When the application is deployed you should be able to access 'https://<fqdn>/'
# to login.
fqdn = "<_Public DNS_name_>"
Once you correct and save the FQDN, run
sudo chef-automate config patch config.toml
and retry opening Chef Automate in your browser.