Upgrade to Chef Automate 4.x
Warning
Chef Automate provides an entire suite of enterprise capabilities for node visibility and compliance. Chef Automate upgrades from one minor version to another automatically. However, Chef Automate will not automatically upgrade to a major version. See the instructions below for manually upgrading Chef Automate from date-based versions to Chef Automate 4.x.
Upgrade Journey
Please choose the following upgrade journey based on your current version of Chef Automate. All of these upgrades are manual upgrades.
Your Current Version | Upgrade To |
---|---|
Any version before 20220329091442 | 20220329091442 |
20220329091442 | 3.0.49 |
3.0.49 | 4.x |
For example, if today you are on version 2021201164433, your upgrade journey should be:
- Manual upgrade to 20220329091442
- Manual upgrade to 3.0.49
- Manual upgrade to 4.x
Upgrade and migration flow
Prerequisites
Note
Warning
- Plan your downtime: This upgrade requires downtime. Before upgrading, set the environment to handle the downtime.
- Backup Chef Automate database: This Chef Automate version upgrades ElasticSearch. Backup your data before upgrading.
- Current version should be 3.0.49: If you are not on 3.0.49 version, do regular upgrades according to your topology.
- Download latest chef-automate cli:
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
Upgrade to Version 3.0.49
Check your current version:
sudo chef-automate version
Note
Note
Normal and airgapped upgrade to 3.0.49
To upgrade to automate 3.0.49 follow the link: upgrading to 3.0.49
Upgrade Path from 3.0.49 to 4.x
There are four possible scenarios to upgrade from 3.0.49 to 4.x version.
Chef Automate in Air-Gapped Environment With Embedded Elasticsearch
Chef Automate in Air-Gapped Environment With External Elasticsearch
Note
Confirm whether your installation is using an external Elasticsearch by running the chef-automate config show
command. If enable=true
is present in the global.v1.external.elasticsearch
config setting, you are using a external Elasticsearch.
If Automate is configured with external Elasticsearch then data should be migrated by user to external OpenSearch.
For Automate configured with embedded Elasticsearch then data will be migrate in the upgrade flow to embedded OpenSearch.
Warning
Chef Automate With Embedded Elasticsearch
To upgrade Chef Automate with embedded Elasticsearch, follow the steps given below:
Upgrade Chef Automate from version 3.0.49 to 4.x
Download latest chef-automate cli.
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
Start a major version upgrade:
sudo ./chef-automate upgrade run --major
#Output Current version: 3.0.49 Target version: 4.x.y This is a major upgrade! In this release, Elasticsearch will be migrated to OpenSearch. Before proceeding, please ensure: 1. You have scheduled downtime for the duration of the upgrade. 2. You have taken a backup by running the command: chef automate backup create. 3. The /hab directory should have at least 5.9GB of free space. (You have current available space : 39.6GB) You can always change the OpenSearch destination directory by using the flag: $ chef-automate upgrade run --major --os-dest-data-dir <path to new directory> For more information, visit https://docs.chef.io/automate/major_upgrade 4.x/ Would you like to proceed with the upgrade? (y/n) y Following Pre-flight checks will be conducted 1. The /hab directory should have at least 5.9GB of free space 2. Elasticsearch indices are in version 6 Pre flight checks [Passed] The /hab directory should have at least 5.9GB of free space [Passed] Elasticsearch indices are in version 6 Maintenance mode turned ON successfully Upgrading Chef Automate from version 3.0.49 to 4.x This might take around 15 to 20 min Once upgrade is complete, You will get an option to migrate data from Elasticsearch to OpenSearch. Maintenance mode will be turned off after migration is complete. To check the upgrade status use $ chef-automate upgrade status
Check the upgrade status of Chef Automate:
sudo chef-automate upgrade status
#Output ------------------------------------------------------------------------------------ Chef Automate upgraded to version: 4.x.y. Find out what's new in version (4.x.y) by visiting visit https://docs.chef.io/release_notes_automate/#4.x.y ------------------------------------------------------------------------------------ Do you wish to migrate the Elasticsearch data to OpenSearch now? (y/n) y Data Migration is in progress Maintenance mode turned ON successfully OpenSearch configurations updated successfully Chef Automate Stopped Data Copied Successfully Chef Automate Started Chef Automate status is healthy Maintenance mode turned OFF successfully Migration complete Verify Chef Automate to see that everything is running and that all your data is available. a2-dev.test #fqdn Once verified, you can remove old Elasticsearch data. Would you like to clean up the old Elasticsearch data now? (y/n) y Clean up successful
[If not done in previous steps] Migrate your data from ElasticSearch 6.8 to OpenSearch 1.2.4:
sudo chef-automate post-major-upgrade migrate --data=es
#Output Do you wish to migrate the Elasticsearch data to OpenSearch now? (y/n) y Data Migration is in progress Maintenance mode turned ON successfully OpenSearch configurations updated successfully Chef Automate Stopped Data Copied Successfully Chef Automate Started Chef Automate status is healthy Maintenance mode turned OFF successfully Migration complete Verify Chef Automate to see that everything is running and that all your data is available. ip-172-31-26-40.ap-south-1.compute.internal Once verified, you can remove old Elasticsearch data.
Verify whether all services are running:
sudo chef-automate status
[If not done in step 2] Clear the old ElasticSearch 6.8 data if all the data is present in your upgraded Chef Automate.
sudo chef-automate post-major-upgrade clear-data --data=es
#Output Would you like to clean up the old Elasticsearch data now? (y/n) y Clean up successful
Chef Automate with External ElasticSearch
To upgrade Chef Automate with external Elasticsearch, follow the steps given below:
Upgrade Chef Automate from version 3.0.49 to 4.x
Download latest chef-automate cli.
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
Start major version upgrade:
sudo ./chef-automate upgrade run --major
#Output Current version: 3.0.49 Target version: 4.x.y This is a major upgrade! In this release, Elasticsearch will be migrated to OpenSearch. Before proceeding, please ensure: 1. You have scheduled downtime for the duration of the upgrade. 2. You have taken a backup by running the command: chef automate backup create. 3. The /hab directory should have at least 5.9GB of free space. (You have current available space : 39.6GB) You can always change the OpenSearch destination directory by using the flag: $ chef-automate upgrade run --major --os-dest-data-dir <path to new directory> For more information, visit https://docs.chef.io/automate/major_upgrade 4.x/ Would you like to proceed with the upgrade? (y/n) y Following Pre-flight checks will be conducted 1. The /hab directory should have at least 5.9GB of free space Pre flight checks [Passed] The /hab directory should have at least 5.9GB of free space Maintenance mode turned ON successfully Upgrading Chef Automate from version 3.0.49 to 4.x ---------------------------------------------------------------------- IMPORTANT To establish connection between automate and OpenSearch database, it is required to patch the configuration file with correct values. We have created a sample config file for configuring external OpenSearch: opensearch_config.toml Once upgrade is complete, you must update this file with actual external OpenSearch connection configurations and then run the below patch command to update the configurations: $ chef-automate config patch opensearch_config.toml ---------------------------------------------------------------------- To check the upgrade status use $ chef-automate upgrade status
Check upgrade status is up-to-date
sudo chef-automate status
#Output ------------------------------------------------------------------------------------ Chef Automate upgraded to version: 4.x.y. Find out what's new in version (4.x.y) by visiting visit https://docs.chef.io/release_notes_automate/#4.x.y ------------------------------------------------------------------------------------ Have you updated your opensearch_config.toml with actual external OpenSearch connection configurations? (y/n) y External OpenSearch configurations updated successfully. Maintenance mode turned ON successfully After the upgrade, you must update opensearch.toml with actual external OpenSearch connection configurations and then run the below patch command to update the configurations: $ chef-automate config patch opensearch.toml Maintenance mode turned ON successfully
Upgrade your external ElasticSearch 6.8 to OpenSearch 1.2.4 manually. If you have configured Host, Port, Username or Password of ElasticSearch, patch the new configuration to use Chef Automate.
All relevant configuration fields of the Elasticsearch should be copied into the OpenSearch configuration.
Please refer to the
elasticsearch.yml
file to get the applied configuration on your external Elasticsearch. Add the relevant configuration from external Elasticsearch (elasticsearch.yml
) to theopensearch.yml
on your external OpenSearch.
Chef Automate in Air-Gapped Environment With Embedded ElasticSearch
Upgrade Chef Automate from version 3.0.49 to 4.x
To upgrade to 4.x, follow the steps below:
On Internet connected machine
Download latest CLI of Chef Automate.
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
Create an Airgap Installation Bundle (AIB).
sudo ./chef-automate airgap bundle create
OR we can directly download via curl request
curl https://packages.chef.io/airgap_bundle/current/automate/latest.aib -o automate-4.x.y.aib
Copy the latest Chef Automate CLI (
chef-automate
) and AIB (automate-4.x.y.aib
) to the air-gapped machine running Chef Automate.
On Air-Gapped machine running Chef Automate
Make sure your upgrade strategy as none in Chef Automate config. Check using:
sudo ./chef-automate config show
Reference to change upgrade strategy
Upgrade using new AIB and Chef Automate CLI:
sudo ./chef-automate upgrade run --airgap-bundle automate-4.x.y.aib --major
#Output Current version: 3.0.49 Target version: 4.x.y This is a major upgrade! In this release, Elasticsearch will be migrated to OpenSearch. Before proceeding, please ensure: 1. You have scheduled downtime for the duration of the upgrade. 2. You have taken a backup by running the command: chef automate backup create. 3. The /hab directory should have at least 5.9GB of free space. (You have current available space : 39.6GB) You can always change the OpenSearch destination directory by using the flag: $ chef-automate upgrade run --major --os-dest-data-dir <path to new directory> For more information, visit https://docs.chef.io/automate/major_upgrade 4.x/ Would you like to proceed with the upgrade? (y/n) y Following Pre-flight checks will be conducted 1. The /hab directory should have at least 5.9GB of free space 2. Elasticsearch indices are in version 6 Pre flight checks [Passed] The /hab directory should have at least 5.9GB of free space [Passed] Elasticsearch indices are in version 6 Maintenance mode turned ON successfully Upgrading Chef Automate from version 3.0.49 to 4.x This might take around 15 to 20 min Once upgrade is complete, You will get an option to migrate data from Elasticsearch to OpenSearch. Maintenance mode will be turned off after migration is complete. To check the upgrade status use $ chef-automate upgrade status
Check the upgrade status of Chef Automate:
sudo chef-automate upgrade status
#Output ------------------------------------------------------------------------------------ Chef Automate upgraded to airgap bundle version: 4.x.y. Find out what's new in version (4.x.y) by visiting visit https://docs.chef.io/release_notes_automate/#4.x.y ------------------------------------------------------------------------------------ Do you wish to migrate the Elasticsearch data to OpenSearch now? (y/n) y Data Migration is in progress Maintenance mode turned ON successfully OpenSearch configurations updated successfully Chef Automate Stopped Data Copied Successfully Chef Automate Started Chef Automate status is healthy Maintenance mode turned OFF successfully Migration complete Verify Chef Automate to see that everything is running and that all your data is available. a2-dev.test #fqdn Once verified, you can remove old Elasticsearch data. Would you like to clean up the old Elasticsearch data now? (y/n) y Clean up successful
[If not done in previous steps] Migrate your data from ElasticSearch 6.8 to OpenSearch 1.2.4:
sudo chef-automate post-major-upgrade migrate --data=es
#Output Do you wish to migrate the Elasticsearch data to OpenSearch now? (y/n) y Data Migration is in progress Maintenance mode turned ON successfully OpenSearch configurations updated successfully Chef Automate Stopped Data Copied Successfully Chef Automate Started Chef Automate status is healthy Maintenance mode turned OFF successfully Migration complete Verify Chef Automate to see that everything is running and that all your data is available. ip-172-31-26-40.ap-south-1.compute.internal Once verified, you can remove old Elasticsearch data.
Verify whether all services are running:
sudo chef-automate status
[If not done in step 2] Clear the old ElasticSearch 6.8 data if all the data is present in your upgraded Chef Automate.
sudo chef-automate post-major-upgrade clear-data --data=es
#Output Would you like to clean up the old Elasticsearch data now? (y/n) y Clean up successful
Chef Automate in Air-Gapped Environment With External ElasticSearch
Upgrade Chef Automate from version 3.0.49 to 4.x
To upgrade to 4.x, follow the steps below:
On Internet connected machine
Download latest CLI of Chef Automate
curl https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
Create an Airgap Installation Bundle (AIB):
sudo ./chef-automate airgap bundle create
OR we can directly download via curl request
curl https://packages.chef.io/airgap_bundle/current/automate/latest.aib -o automate-4.x.y.aib
Copy the latest Chef Automate CLI (
chef-automate
) and AIB (automate-4.x.y.aib
) to the air-gapped machine running Chef Automate.
On Air-Gapped machine running Chef Automate
Make sure your upgrade strategy as none in Chef Automate config. Check using:
sudo ./chef-automate config show
Reference to change upgrade strategy
Upgrade using new AIB and Chef Automate CLI:
sudo ./chef-automate upgrade run --airgap-bundle automate-4.x.y.aib --major
#Output Current version: 3.0.49 Target version: 4.x.y This is a major upgrade! In this release, Elasticsearch will be migrated to OpenSearch. Before proceeding, please ensure: 1. You have scheduled downtime for the duration of the upgrade. 2. You have taken a backup by running the command: chef automate backup create. 3. The /hab directory should have at least 5.9GB of free space. (You have current available space : 39.6GB) You can always change the OpenSearch destination directory by using the flag: $ chef-automate upgrade run --major --os-dest-data-dir <path to new directory> For more information, visit https://docs.chef.io/automate/major_upgrade 4.x/ Would you like to proceed with the upgrade? (y/n) y Following Pre-flight checks will be conducted 1. The /hab directory should have at least 5.9GB of free space Pre flight checks [Passed] The /hab directory should have at least 5.9GB of free space Maintenance mode turned ON successfully Upgrading Chef Automate from version 3.0.49 to 4.x ---------------------------------------------------------------------- IMPORTANT To establish connection between automate and OpenSearch database, it is required to patch the configuration file with correct values. We have created a sample config file for configuring external OpenSearch: opensearch_config.toml Once upgrade is complete, you must update this file with actual external OpenSearch connection configurations and then run the below patch command to update the configurations: $ chef-automate config patch opensearch_config.toml ---------------------------------------------------------------------- To check the upgrade status use $ chef-automate upgrade status
Check upgrade status is up-to-date
sudo chef-automate status
#Output ------------------------------------------------------------------------------------ Chef Automate upgraded to airgap bundle version: 4.x.y. Find out what's new in version (4.x.y) by visiting visit https://docs.chef.io/release_notes_automate/#4.x.y ------------------------------------------------------------------------------------ Have you updated your opensearch_config.toml with actual external OpenSearch connection configurations? (y/n) y External OpenSearch configurations updated successfully. Maintenance mode turned ON successfully After the upgrade, you must update opensearch.toml with actual external OpenSearch connection configurations and then run the below patch command to update the configurations: $ chef-automate config patch opensearch.toml Maintenance mode turned ON successfully
Upgrade your external ElasticSearch 6.8 to OpenSearch 1.2.4 manually. If you have configured Host, Port, Username or Password of ElasticSearch, patch the new configuration to use Chef Automate.
All relevant configuration fields of the Elasticsearch should be copied into the OpenSearch configuration.
Please refer to the
elasticsearch.yml
file to get the applied configuration on your external Elasticsearch. Add the relevant configuration from external Elasticsearch (elasticsearch.yml
) to theopensearch.yml
on your external OpenSearch.
Note
Troubleshooting
Circuit Breaking Exception
{"error":{"root_cause":[{"type":"circuit_breaking_exception","reason":"[parent] Data too large, data for [<http_request>] would be [6126524880/5.7gb], which is larger than the limit of [5988548608/5.5gb], real usage: [6126524880/5.7gb], new bytes reserved: [0/0b], usages [request=0/0b, fielddata=74975/73.2kb, in_flight_requests=0/0b, accounting=89882860/85.7mb]","bytes_wanted":6126524880,"bytes_limit":5988548608,"durability":"PERMANENT"}]
- Update the Opensearch Config, using
chef-automate config patch <config_patch.toml>
[opensearch]
[opensearch.v1]
[opensearch.v1.sys]
[opensearch.v1.sys.runtime]
heapsize = "8g" # This should be Half of RAM
[opensearch.v1.sys.indices]
[opensearch.v1.sys.indices.breaker]
total_limit = "95%"
Shard Failure
[ERROR] Elasticsearch exception [type=validation_exception, reason=Validation Failed: 1: this action would add [5] total shards, but this cluster currently has [997]/[1000] maximum shards open;]
To address the issue of shard limit hitting 1000, we need to increase the max_shards_per_node
Update the Opensearch Config, using chef-automate config patch <config_patch.toml>
[opensearch]
[opensearch.v1]
[opensearch.v1.sys]
[opensearch.v1.sys.cluster]
max_shards_per_node = "<NUMBER_OF_SHARD>"
Proxy Setting issue
If you are using Proxy Settings and have upgraded to a version between 4.0.27 and 4.2.10, then you might get this error when you upgrade:
DeploymentServiceCallError: A request to the deployment-service failed: Request to get upgrade status failed: rpc error: code = Unknown desc = error in getting the versions from current channel: error in invoking the endpoint https://packages.chef.io/manifests/current/automate/versions.json: Get "https://packages.chef.io/manifests/current/automate/versions.json": dial tcp: lookup packages.chef.io on 10.2.72.20:53: read udp 10.1.97.98:59620->10.2.72.20:53: i/o timeout
To move ahead with upgrade you can download latest CLI and Airgapped bundle using curl command with proxy settings:
curl -x http://proxy_server:proxy_port --proxy-user username:password -L https://packages.chef.io/files/current/latest/chef-automate-cli/chef-automate_linux_amd64.zip | gunzip - > chef-automate && chmod +x chef-automate
curl -x http://proxy_server:proxy_port --proxy-user username:password -L https://packages.chef.io/airgap_bundle/current/automate/latest.aib -o automate-latest.aib
After downloading, run the upgrade command with airgapped bundle option:
./chef-automate upgrade run --airgap-bundle automate-latest.aib
Output will look like this:
Installing airgap install bundle
Trying to restart Deployment Service...
Deployment service is stopped
Waiting for Deployment Service to be healthy
Waiting for Deployment Service to be healthy
Waiting for Deployment Service to be healthy
Deployment Service is healthy now
current_version:"4.x" target_version:"4.x.y" target_major:"4"
Upgrading Chef Automate
Minor upgrade errors
sudo ./chef-automate upgrade run --airgap-bundle x.x.x.aib
The above error occurs if you run Chef Automate with Proxy settings and upgrade it from the Automate version before 4.2.22 to after 4.2.22.
Installing airgap install bundle
DeploymentServiceCallError: A request to the deployment-service failed: Request to start to upgrade failed: RPC error: code = FailedPrecondition desc = The minimum compatible version field is missing in the manifest. Create a bundle with the latest automate-cli
This error may occur if a user running a non-airgapped version of Chef Automate tries to perform a minor upgrade using the airgapped installation method. To fix this minor upgrade error, run the following command:
sudo chef-automate stop
Once done, run the following command:
sudo chef-automate start
Before trying the upgrade again, confirm whether all the services are up by running the following command:
sudo chef-automate status
Migration Fails
If Chef Automate fails to migrate your data to OpenSearch 1.2.4 while running chef-automate post-major-upgrade migrate --data=es
, restore the data using:
sudo chef-automate backup restore </path/to/backups/>BACKUP_ID
To restore your Air-Gapped bundle, run the following command:
sudo chef-automate backup restore --airgap-bundle </path/to/bundle> </path/to/backups/>BACKUP_ID
For more information, see Restore Methods.
To start the upgrade, use the backup ID from the backup created. In case the restore fails even after upgrading the Chef Automate version, follow the steps given below:
Uninstall Chef Automate.
sudo chef-automate uninstall
Install the last major version (
3.0.49
) using the air-gapped installation process.Restore the backup:
sudo chef-automate backup restore <backup_id>
Refer to the Chef Automate Restore documentation.
Note
/hab/svc/deployment-service/var/upgrade_metadata.json
file if the migration of data has been done using backup and restore method.Adding Custom Configuration to optimize OpenSearch Performance
To add custom configurations or optimizing OpenSearch performance please refer to Custom OpenSearch configuration docs.