Recently we had to provision a couple of NetEye machines on Azure for production purposes.
Our procedure essentially creates a RedHat 8.10 VM starting with an official RedHat image, and adds the NetEye repositories to install the required software. This procedure is what we usually follow to create training environments, but these machines are usually not meant to have a long life and we never update them.
During an upgrade of productive machines we spotted an issue related to dnf which found conflicts with grafana
and ansible-core
. After some investigation we found out that the issue was related to Azure, which was adding its own repository definition because it was exploiting RHUI functionalities.
Red Hat Update Infrastructure is officially supported by Red Hat and allows a Cloud provider to handle updates via its own repositories, both mirroring Red Hat repositories themselves and also adding custom repositories.
In the specific case of Azure those repos are defined in /etc/yum.repos.d/rh-cloud.repo
which supersedes Red Hat’s official repos.
For our specific case we need a “recent but not bleeding edge” updated version of some elements of the software (grafana
and ansible-core
), and so we exclude these software packages from the official Red Hat repos during our setup procedures by using the following command:
subscription-manager repo-override --repo=rhel-8-for-x86_64-appstream-rpms --add=exclude:grafana*,ansible-core*
Unfortunately, RHUI repos are supported by Red Hat but not handled by subscription-manager
, meaning that this exclude will not work for them.
After some investigation and confirmation from Red Hat support, it turned out that we have several options:
/etc/dnf/dnf.conf
/etc/yum.repos.d/rh-cloud.repo
renaming it for example to rh-cloud.repo.disable/etc/yum.repos.d/rh-cloud.repo
for rhel-8-for-x86_64-appstream-rhui-rpms
Each solution has its pro and cons, but none of them are perfect for our situation:
rhui-azure-rhel8
may re-enable repos at any timeWe opted for the fourth solution: it still poses the issue related to possible updates of rhui-azure-rhel8
packages but at least it doesn’t disable Azure repos.
The solution is also relatively simple to automate to guarantee that, during upgrades, the exclusion line is present.
In general RHUI repos don’t cause any issues and can be used safely to achieve better performance and provider-side cluster customization. In some specific cases, however, they can interfere with usual operations and unfortunately they cannot be managed via subscription-manager.
In those specific cases you should apply some workarounds like those described above and understand which solution is best for your specific case.
Did you find this article interesting? Are you an “under the hood” kind of person? We’re really big on automation and we’re always looking for people in a similar vein to fill roles like this one as well as other roles here at Würth Phoenix.