Updating LogScale
You should always check the Release Notes for all versions between the version of LogScale you are currently running and the version you are installing.
Important
When upgrading, all notes in the cluster should be updated to the same version. Although running different versions on different nodes may work, it is not a supported deployment configuration.
The recommended method for updating a whole LogScale requires updating the whole cluster at the same time to the new version. This requires downtime for the cluster as the entire will need to be offline to complete the upgrade. The basic process is as follows:
If you have different node pools where individual nodes have been
configured as specific ingestonly
and httponly
nodes:
Upgrade the non-
ingestonly
nodes first:Stop the non-
ingestonly
nodesUpgrade the non-
ingestonly
nodesStart the non-
ingestonly
nodes
Upgrade the
ingestonly
nodes in a rolling fashion (i.e. one node at a time). For each each node:Stop the node
Upgrade the node
Restart the node and wait until the node is accepting data.
Upgrading in this way enables the cluster to continuing accepting data without blocking or rejecting ingest requests.
If you all your nodes share all roles within the cluster, it is best to upgrade each node in a rolling fashion, upgrading each node in turn:
Shut down each node
Updat each node to the new version of LogScale
Start up each node
Updating a Node
Updating LogScale is a matter of stopping the old running version and starting the new version, on top of the same data directories, and with the same configuration, in most cases. Some releases have instructions in their release notes on required steps to update, but most releases should run on top of the previous one.
We recommend that you make a backup copy of the file
$DATA_DIR/humio-data/global-data-snapshot.json
before you update — preferably after shutting down the old version
but before starting the new one. This file can be used to roll back to
the previous version if necessary.
Updating LogScale Running in Docker
When using Docker images to run LogScale, update by pulling the latest version of the Docker image and running it using the same Docker arguments as previously.
All LogScale images are tagged with a version:
latest
— the latest stable version of LogScalestable
— the latest stable version of LogScalepreview
— the latest preview version of LogScale
In the example below, latest
is used as version to
update the single image Docker version, where everything is inside a
single Docker container:
Stop the docker instance:
shell$ docker stop humio
Remove the docker instance:
shell$ docker rm humio
Pull the latest version:
shell$ docker pull humio/humio:latest
Restart the the instnace with the updated docker image:
shell$ docker run \ -v $YOUR_LOGSCALE_URL_DATA_DIR:/data \ --net=host \ --detach \ --restart=always \ --name=humio \ --stop-timeout 300 \ --env-file=$PATH_TO_CONFIG_FILE humio/humio
Updating LogScale Running from tar.gz
When using tar.gz
downloads to
run LogScale, update by following these steps.
Download the tarball.
Terminate LogScale:
shell$ cd /var/humio $ ps -ef|grep humio|awk '{ print $1 }'|xargs kill
Delete
humio/bin
andhumio/libs
directories:shell$ rm -rf bin libs
Extract the new tarball:
shell$ cd /var $ tar zxf server-1.82.4.tar.gz
Restart the service. If done manually from the terminal, execute the following command (does not apply for LogScale instances run by services like systemd):
shell$ cd /var/humio $ ./bin/humio-server-start.sh
Updating LogScale Running in Kubernetes
If running the Humio Operator, see the Upgrading Humio Operator on Kubernetes documentation.
If running the LogScale Helm Chart, see the Upgrading with Kubernetes section of the Helm Chart documentation page.
Warning
This is generally not recommended for version updates but is convenient for configuration changes.
Update the
values.yaml
file with the new configuration.Update the statefulset/pods with the new configuration by running:
logscalehelm upgrade --values values.yaml humio humio/humio-helm-charts