Upgrade from LiCO 7.2.0 to 7.2.1 for Container Deployment

Introduction

This Guide describes how to upgrade LiCO container from V7.2.0 to V7.2.1.

Prerequisites

Operating environment

Before upgrading LiCO, ensure the version of the operating system, OpenHPC, and Icinga are listed in the following table. To use LiCO 7.2.1 in the required operating system, install LiCO 7.2.1 by following the instructions of LiCO 7.2.1 Installation Guide (for EL8).

LiCO version Red Hat (RHEL) Rocky/EL8 Lenovo OpenHPC version Icinga version
V7.2.0 8.6 8.6 2.6.2 2.13.8
V7.2.1 8.8 8.8 2.8 2.14.2

Prepare

1. Stop LiCO Container

lico-control stop
docker rename lico lico_7.2.0

2.Prepare to upgrade

Step 1. Log in to the management node.

Step 2. Edit /root/lico_release.local and update the environment variables listed in that file:

# Management node hostname
sms_name="head"
# IP address of management node
sms_ip="192.168.0.2"
# Old version of repository directory for LiCO and the version of LiCO in
# the current system
original_lico_repo_dir="/install/custom/lico-7.2.0"
# Old version of repository directory for LiCO-dep and
# the version of LiCO-dep in the current system
original_lico_dep_repo_dir="/install/custom/lico-dep-7.2.0"
# New version of repository directory for LiCO, please change it according to LiCO version
new_lico_repo_dir="/install/custom/lico-7.2.1"
# New version of LiCO repository directory for LiCO-dep,
# please change it according to LiCO-dep version
new_lico_dep_repo_dir="/install/custom/lico-dep-7.2.1"
# Link name of LiCO repository directory for LiCO
link_lico_repo_dir="/install/custom/lico"
# Link name of LiCO repository directory for LiCO-dep
link_lico_dep_repo_dir="/install/custom/lico-dep"
# Existing shared directories for LiCO
lico_share_dir="/home"
# Shared directories of repo file in LiCO Installation Guide
share_installer_dir="/install/installer"
# link name of directory for lico moniotr
link_lico_monitor_dir="/install/custom/lico-monitor"
# Local directory for for lico monitor, please change it according to this version.
lico_monitor_dir="/install/custom/lico-monitor-1.1.1"

Step 3. Save the changes to lico_release.local and reload the environment variables:

chmod 600 lico_release.local
source lico_release.local

3. Build LiCO image

Step 1. Prepare packages. Download the following packages and upload all of them to the /root directory:

Step 2. Prepare build environment:

cd /root
lico_container_workspace="/root/lico-workspace/7.2.1"
mkdir -p $lico_container_workspace
tar -xzvf lico-docker-7.2.1.x86_64.tar.gz -C $lico_container_workspace
mv Lenovo-OpenHPC-2.8.EL8.x86_64.tar $lico_container_workspace
mv lico-dep-7.2.1.el8.x86_64.tgz $lico_container_workspace
mv lico-release-7.2.1.el8.x86_64.tar.gz $lico_container_workspace
mv authselect.tar.gz $lico_container_workspace

cp $lico_container_workspace/lico-docker/Dockerfile \
$lico_container_workspace/lico-docker/scripts/build.sh $lico_container_workspace

\cp $lico_container_workspace/lico-docker/scripts/lico-control /usr/bin/

chmod +x $lico_container_workspace/build.sh
chmod +x /usr/bin/lico-control

Step 3. Build LiCO image:

cd $lico_container_workspace
./build.sh

4. Backup

backup_dir=/root/lico_7.2.0_backup/
mkdir -p $backup_dir
cd $lico_container_workspace/lico-docker/upgrade
python3 container-upgrade backup --backup-path $backup_dir --backup-db --backup-config --backup-sharedir

If the /opt/lico/cloud/azure/slurm.conf file exists, back it up:

cp /opt/lico/cloud/azure/slurm.conf /opt/lico/cloud/azure/slurm.conf.bak

Upgrade software on management node

Step 1. Upgrade LiCO icinga2 plugin:

systemctl stop icinga2
nodeshell all systemctl stop icinga2
rm -rf /opt/lico/pub/monitor
mkdir -p $lico_monitor_dir
cd /root
tar -xvzf openlico-monitor-1.1.1.x86_64.tgz -C $lico_monitor_dir
rm -rf $link_lico_monitor_dir
ln -s $lico_monitor_dir $link_lico_monitor_dir
dnf install -y python39
nodeshell all dnf install -y python39
cd $link_lico_monitor_dir
python3 $link_lico_monitor_dir/install.py -p python3.9

Step 2. Set and create a backup directory:

icinga_backup="/install/icinga2/backup"
mkdir -p $icinga_backup

Step 3. Configure icinga global template file on management node:

Step 4. Define icinga zone file:

Step 5. Enable influxdb writer feature for icinga:

Step 6. Restart the icinga2 service to make the changes take effect.

nodeshell all systemctl restart icinga2
systemctl restart icinga2

Deploy LiCO 7.2 container

Step 1. Prepare the mount folder and configure the file

rm -rf /etc/lico
lico-control prepare

Step 2. merge the config file

cp $backup_dir/head/configure/lico/nodes.csv /etc/lico/
cd /root/lico-workspace/7.2.1/lico-docker/upgrade/
python3 container-upgrade merge-config --backup-path $backup_dir

If the /opt/lico/cloud/azure/slurm.conf.bak file exists, restore it:

mv /opt/lico/cloud/azure/slurm.conf.bak /opt/lico/cloud/azure/slurm.conf

Step 3. Edit the following configuration in the /etc/lico/lico.ini file

[DATABASE]
HOST = '127.0.0.1'
PORT = 3306

[TRANSITER]
HOST = '127.0.0.1'
PORT = 22

Step 4. Initial data for LiCO

lico-control init --mode  lico

lico-control init --mode  cloudtools

Step 5. Start the Container

lico-control run
lico-control docker-cmd remove lico_7.2.0

Rollback

Stop LiCO 7.2.1 container
lico-control stop
lico-control docker-cmd rename lico lico_7.2.1
restore database, config files and share dir
cd $lico_container_workspace/lico-docker/upgrade/
python3 container-rollback --backup-path $backup_dir --restore-db --restore-sharedir
restore software in management node
systemctl stop icinga2
nodeshell all systemctl stop icinga2
rm -rf /opt/lico/pub/monitor
source lico_env.local 
mkdir -p $lico_monitor_dir
tar -xvzf openlico-monitor-1.1.0.x86_64.tgz -C $lico_monitor_dir
rm -rf $link_lico_monitor_dir
rm -rf $new_lico_monitor_dir
ln -s $lico_monitor_dir $link_lico_monitor_dir
python3 $link_lico_monitor_dir/install.py

cp $icinga_backup/commands.conf /etc/icinga2/zones.d/global-templates/commands.conf
cp $icinga_backup/hosts.conf /etc/icinga2/zones.d/master/hosts.conf
cp $icinga_backup/service.conf /etc/icinga2/zones.d/master/service.conf
cp $icinga_backup/influxdb.conf /etc/icinga2/features-available/influxdb.conf

influx -username <influxdb username> -password <influxdb password>
drop database icinga
create database icinga
use icinga
create retention policy "three_hour_only" on "icinga" duration 3h replication 1 default
exit

nodeshell all systemctl restart icinga2
systemctl restart icinga2
start LiCO 7.2 container
lico-control run  --image lico:7.2.0
lico-control docker-cmd remove lico_7.2.1