Installation on CentOS/RHEL


To run Python 3.x on CentOS or RHEL (Red Hat Enterprise Linux), Software Collections needs to be activated first.

Using Software Collections

First of all install the software collection repository as root and scl utils. For example, on CentOS:

sudo yum install centos-release-scl
sudo yum-config-manager --enable centos-sclo-rh-testing
sudo yum install -y scl-utils

Install some dependencies you’ll need later.

sudo yum install gcc gcc-c++ systemd-devel

Then install the Python 3.6 package. If you are using CentOS 7 then you may have to install the packages for Python 3.6 using RHEL Methods listed here: https://www.softwarecollections.org/en/scls/rhscl/rh-python36/) for this to work as mentioned above.

sudo yum install rh-python36

This is part of the slight change when trying to install Python 3.6 and running the command python36 --version which will after install give you the correct version, but won’t allow you to set the software collection using the scl command. This command downloads the RH collection of Python to allow you to run scl command to enable the environment in bash and then run the automate command using the template.

yum install rh-python36

Start using software collections

scl enable rh-python36 bash

Once installed, switch to your openpeerpower user (if you’ve set one up), enable the software collection and check that it has set up the new version of Python:

$ python --version
Python 3.6.3

You will be in a command shell set up with Python 3.6 as your default version. The virtualenv and pip commands will be correct for this version, so you can now create a virtual environment and install Open Peer Power following the main instructions.

You will need to enable the software collection each time you log on before you activate your virtual environment.

Systemd with Software Collections

To autostart Open Peer Power using systemd and a python36 (from SCL) virtual environment, follow the main instructions and adjust the template as follows:

Filename: /etc/systemd/system/open-peer-power@openpeerpower.service

[Unit]
Description=Open Peer Power
After=network-online.target

[Service]
Type=simple
# %i means the username is derrived from the filename.
User=%i
# a python venv for opp exists in /opt/opp/venv
ExecStart=/srv/openpeerpower/bin/opp

[Install]
WantedBy=multi-user.target

This works because the Python virtual environment was created using the SCL environment, thus there is no need to activate SCL.